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
相关推荐
KingRumn2 小时前
Linux信号之标准信号与实时信号BestAns4 小时前
一文带你吃透 Java 反射机制wasp5204 小时前
AgentScope Java 核心架构深度解析2501_916766544 小时前
【Springboot】数据层开发-数据源自动管理自在极意功。5 小时前
MyBatis 动态 SQL 详解:从基础到进阶实战软件管理系统5 小时前
基于Spring Boot的便民维修管理系统源代码•宸5 小时前
Leetcode—620. 有趣的电影&&Q3. 有趣的电影【简单】百***78755 小时前
Step-Audio-2 轻量化接入全流程详解快乐肚皮5 小时前
MySQL递归CTE