java二维数组旋转_java旋转二维数组实例

本文提供了一个Java实例,展示了如何旋转二维数组,使得数字按螺旋顺序排列。代码中包含一个`specArr`方法用于生成螺旋排列的二维数组,并通过`arrprint`方法进行打印展示。该程序对于理解Java二维数组操作及螺旋填充算法有帮助。
摘要由CSDN通过智能技术生成

本文实例讲述了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程序设计有所帮助。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值