备考蓝桥杯(10)矩阵旋转 java实现
2018-03-29 20:09
218 查看
package pers.robert.lanqiaobeizhenti129; /** * 20.方阵顺时针旋转 对一个方阵转置,就是把原来的行号变列号,原来的列号变行号 例如,如下的方阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 转置后变为: 1 5 9 13 2 6 10 14 3 7 11 15 4 8 12 16 但,如果是对该方阵顺时针旋转(不是转置),却是如下结果: 13 9 5 1 14 10 6 2 15 11 7 3 16 12 8 4 下面的代码实现的功能就是要把一个方阵顺时针旋转。 * @author Robert * */ public class The020RotationOfTheSquareArrayDemo1 { // 矩阵顺时针旋转 public static void rotation(int[][] n,int [][] m,int i,int j){ int t = j; // 标记最后一行的位置 if(i>=n.length) return; for(int k=0;k<n.length;k++){ m[i][k] = n[j--][i]; // 解决一行 } print(m); rotation(n,m,++i,t); // 递归解决下一行 } // 输出矩阵 public static void print(int[][] t){ for(int[] x: t){ for(int y:x){ System.out.print(y+"\t"); } System.out.println(); } } public static void main(String[] args){ int[][] n = { {1 ,2 ,3 ,4 }, {5 ,6 ,7 ,8 }, {9 ,10,11,12}, {13,14,15,16} }; print(n); // 显示原矩阵 int len = n.length; int[][] m = new int[len][len]; // 目标矩阵 rotation(n,m,0,len-1); // 矩阵顺时针旋转 System.out.println("顺时针旋转结果:"); print(m); // 显示目标矩阵 } }
分析:这种题主要是找到转换规则,新建一个目标矩阵,在按照规则逐行替换
相关文章推荐
- 备考蓝桥杯(13)顺时针螺旋填入矩阵 java实现
- 备考蓝桥杯(9)密码转换器 java实现
- 备考蓝桥杯(1)算式☆☆☆ + ☆☆☆ = ☆☆☆ java 实现(全排列)
- 备考蓝桥杯(23)G将军准备敢死队 java实现
- 备考蓝桥杯(18)方格填数 java实现
- 备考蓝桥杯(29)基因牛的繁殖java实现
- 备考蓝桥杯(16)包子问题 java实现
- 备考蓝桥杯(6)纵横火柴游戏 java实现
- 备考蓝桥杯(34)泊松汾酒java实现exeforward
- 备考蓝桥杯(27)迷宫走法(java实现)
- Java实现矩阵顺时针旋转90度
- 备考蓝桥杯(14)playfair加密java实现
- 备考蓝桥杯(30)奇怪的比赛java实现(exeforward)
- 备考蓝桥杯(17)K倍区间 java实现
- 备考蓝桥杯(12)输入日期 java实现
- 备考蓝桥杯(26)漏掉的账单明细,(遍历所有情况)(java实现)(exforward)
- 备考蓝桥杯(7)源码转换 java实现
- 备考蓝桥杯(38)迭代器输出java实现
- 备考蓝桥杯(8)取球博弈 java实现
- 备考蓝桥杯(19)方格填数(DFS) java实现