public class test28 {
public static void rotate(int[][] matrix){
int a =0;
int b =0;
int c = matrix.length-1;
int d = matrix[0].length-1;
while (a < c){//由于是正方形,所以行越界列一定越界
rotateEdge(matrix , a++ , b++ , c-- ,d--);
}
}
public static void rotateEdge(int[][] m, int a, int b, int c,int d){
int tmp = 0;
for(int i =0 ; i < d-b ;i++){//有多少组次
//m[a][b+i]上面一组
//m[a+i][d]右边一组
//m[c][d-i]下面一组
//m[c-i][b]左边一组
//然后不断组与组变换解决
tmp = m[a][b+i];
m[a][b+i] = m[c-i][b];
m[c-i][b] = m[c][d-i];
m[c][d-i] = m[a+i][d];
m[a+i][d] =tmp;
}
}
}
原地旋转正方形矩阵
听风客12024-08-06 9:40
相关推荐
leo__52015 小时前
基于两步成像算法的聚束模式SAR MATLAB实现前端小白在前进16 小时前
力扣刷题:在排序数组中查找元素的第一个和最后一个位置AM越.16 小时前
Java设计模式详解--装饰器设计模式(含uml图)59803541517 小时前
【java工具类】小数、整数转中文大写JIngJaneIL17 小时前
基于java + vue个人博客系统(源码+数据库+文档)某林21217 小时前
基于SLAM Toolbox的移动机器人激光建图算法原理与工程实现吃喝不愁霸王餐APP开发者17 小时前
Java后端服务在对接全国性霸王餐API时的多数据中心部署与就近调用策略从心归零17 小时前
springboot-jpa的批量更新方法修炼地17 小时前
代码随想录算法训练营第四十三天 | 图论理论基础、深搜理论基础、卡码网98. 所有可达路径、797. 所有可能的路径、广搜理论基础iAkuya17 小时前
(leetcode)力扣100 23反转链表(迭代||递归)