LeetCode【48】旋转图像

题目:

思路:

第一种思路:使用额外二维矩阵,变化后的直接存入额外的矩阵,不符合题意

以示例2中,第3行,第1列的13为例,旋转后,变为了第1行,第2列

旋转90 后行的位置,变为:原列序号

旋转90 后列的位置,变为:n-原行的位置+1

第二种思路:使用翻转代替旋转

注:掌握技巧后,代码不易出错

代码:

java 复制代码
public void rotate(int[][] matrix) {

    int rows = matrix.length;
    int columns = matrix[0].length;

    // 先翻转行
    for (int i = 0; i < rows / 2; i++) {
        for (int j = 0; j < columns; j++) {
            int temp = matrix[rows - i - 1][j];
            matrix[rows - i - 1][j] = matrix[i][j];
            matrix[i][j] = temp;
        }
    }

    // 沿主对角线翻转
    for (int i = 0; i < rows; i++) {
        for (int j = 0; j < i; j++) {  // 这里要注意,如果每个元素都翻转,最后又转回来了,沿主对角线,一行一列,两行两列,三行三列,column <= rows 对角线不用换,column < row
            int temp = matrix[i][j];
            matrix[i][j] = matrix[j][i];
            matrix[j][i] = temp;
        }
    }

}
相关推荐
SWAGGY..14 分钟前
Linux系统编程:(十三)环境变量
java·linux·算法
Black蜡笔小新24 分钟前
自动化AI算法训练服务器DLTM一体化训推平台构建企业专属AI能力中台
人工智能·算法·自动化
sjsjs1137 分钟前
力扣3558. 给边赋权值的方案数 I
算法·leetcode·职场和发展
hujinyuan2016038 分钟前
2025年12月中国电子学会青少年机器人技术等级考试试卷(四级) 真题+答案
算法·机器人
啦啦啦啦啦zzzz41 分钟前
算法总结(双指针)
c++·算法·双指针
花间相见1 小时前
【LeetCode01】—— 无重复字符的最长子串:滑动窗口经典题详解
python·算法·leetcode
wabs6661 小时前
关于动态规划【力扣96.不同的二叉搜索树的递推公式怎么理解?】
算法·动态规划
嵌入式ZYXC1 小时前
第8篇:《面试题:模拟地和数字地为什么要分开?怎么接?》
stm32·单片机·嵌入式硬件·面试·职场和发展
QiLinkOS1 小时前
极客与商业思维的融合实践(1)
c语言·数据库·c++·人工智能·算法·开源协议
fu的博客1 小时前
【数据结构16】图:基于邻接矩阵、邻接表实现DFS/BFS
数据结构·算法