加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java旋转二维数组实例

发布时间:2020-12-14 05:05:49 所属栏目: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开始的

本篇章节讲解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程序设计有所帮助。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读