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
相关推荐
我叫张小白。2 分钟前
Spring Boot拦截器详解:实现统一的JWT认证Gerardisite2 小时前
如何在微信个人号开发中有效管理API接口?gfdhy3 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用闲人编程3 小时前
Python的导入系统:模块查找、加载和缓存机制百***06013 小时前
SpringMVC 请求参数接收故渊ZY3 小时前
Java 代理模式:从原理到实战的全方位解析匿者 衍3 小时前
POI读取 excel 嵌入式图片(支持wps 和 office)一个尚在学习的计算机小白3 小时前
java集合IUGEI3 小时前
synchronized的工作机制是怎样的?深入解析synchronized底层原理q***13614 小时前
Windows操作系统部署Tomcat详细讲解