java旋转二维数组实例
更新时间:2014年10月29日 11:36:08 投稿:shichen2014
这篇文章主要介绍了java旋转二维数组,以实例形式较为详细的讲述了旋转二维数的原理与实现方法,需要的朋友可以参考下
本文实例讲述了java旋转二维数组的操作,分享给大家供大家参考。具体实现方法如下:
复制代码 代码如下:
package test;
/*
* 1 2 3 4 5
* 16 17 18 19 6
* 15 24 25 20 7
* 14 23 22 21 8
* 13 12 11 10 9
*
* 写一方法,打印等长的二维数组,要求从1开始的自然数由方阵的最外圈向内螺旋方式地顺序排列。
* */
public class Test6
{
public static void main(String[] args)
{
arraynum(4);
}
// 便于改代码..输入不同y值输出不同的二维数列
private static void arraynum(int x)
{
int[][] arr = new int[x][x];
int len = arr.length, max = 0, count = 0;
specArr(arr, len, max, count);
arrprint(arr);
}
// 高级for输出打印用的
private static void arrprint(int[][] arr)
{
for (int[] in : arr)
{
for (int t : in)
{
System.out.print(t + "\t");
}
System.out.println();
}
}
private static void specArr(int[][] arr, int len, int max, int count)
{
while (len > 0)
{
int j = 0;
for (int index = 0; index < (len - 1) * 4; index++)
{
if (index < len - 1)
arr[0 + count][index + count] = ++max;
else if (index < 2 * (len - 1))
arr[count + j++][arr.length - 1 - count] = ++max;
else if (index < 3 * (len - 1))
arr[arr.length - 1 - count][(j--) + count] = ++max;
else if (index < 4 * (len - 1))
arr[arr.length - 1 - (j++) - count][0 + count] = ++max;
}
if (len == 1)
{
arr[arr.length / 2][arr.length / 2] = max + 1;
}// 注意到 当y值为奇数时,会有循环到n=1的情况,需要补进数组最中间值
count++;
len = len - 2;
}
}
}
希望本文所述对大家的Java程序设计有所帮助。
相关文章
Spring Boot ActiveMQ发布/订阅消息模式原理解析
这篇文章主要介绍了Spring Boot ActiveMQ发布/订阅消息模式原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2020-07-07Spring Boot2与Spring Boot3的区别小结
SpringBoot2和SpringBoot3之间有一些重要的区别,本文就来探讨SpringBoot2和SpringBoot3之间的区别,具有一定的参考价值,感兴趣的可以了解一下2023-10-10JavaWeb入门:HttpResponse和HttpRequest详解
这篇文章主要介绍了Django的HttpRequest和HttpResponse对象,分享了相关代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下2021-07-07
最新评论