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程序设计有所帮助。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- java – 在哪里/如何为Tomcat .war文件设置配置资源
- java – Eclipse:保存没有保存操作
- Java实现JS中的escape和UNescape代码分享
- java – 为什么CountDownLatch.getCount()返回一个long而不
- java – 不支持的类:com.mediatek.common.telephony.IOnly
- java – 无法捕获ConstraintViolationException
- Java自学-类和对象 枚举类型
- java – 如何记录nutch插件的执行情况
- Mybatis中的延迟加载案例解析
- java – 如何在Netbeans上定义jRadioButton的标签位置?