力扣-48-旋转图像
感觉其实顺时针转90°的话,其实就相当于把原矩阵横纵互换
而且题目还限定了n*n矩阵
但是要求原地换
题解1方法使用辅助数组,而3方法翻转再镜像其实都不是题目所期望的
但是2方法实际上是数学解法
方法三:先上下翻转再对角线翻转
class Solution { public: void rotate(vector<vector<int>>& matrix) { int n = matrix.size();// 行数 // 上下翻转 for(int i=0;i<n/2;++i){ for(int j=0;j<n;++j){ swap(matrix[i][j],matrix[n-i-1][j]); } } // 对角线翻转 for(int i=0;i<n;++i){ // 注意这个j<i,实现了只要翻转左下三角 for(int j=0;j<i;++j){ swap(matrix[i][j],matrix[j][i]); } } } };
Java实现没什么特别的,只是Java中没有swap()
函数,自己手动交换了而已
本文作者:YaosGHC
本文链接:https://www.cnblogs.com/yaocy/p/16372159.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!