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
相关推荐
狂奔小菜鸡19 分钟前
Day40 | Java中的ReadWriteLock读写锁颜酱1 小时前
从0到1实现LFU缓存:思路拆解+代码落地SimonKing1 小时前
JetBrains 用户狂喜!这个 AI 插件让 IDE 原地进化成「智能编码助手」狂奔小菜鸡2 小时前
Day39 | Java中更灵活的锁ReentrantLock颜酱2 小时前
从0到1实现LRU缓存:思路拆解+代码落地NE_STOP14 小时前
MyBatis-配置文件解读及MyBatis为何不用编写Mapper接口的实现类后端AI实验室19 小时前
用AI写代码,我差点把漏洞发上线:血泪总结的10个教训CoovallyAIHub19 小时前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!CoovallyAIHub21 小时前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度