LeetCode第48题旋转图像

继续打卡算法题,今天学习的是LeetCode第48题旋转图像,这道题目是道中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

本题需要将二维数组90度旋转,通过分析例子可以得到规则,从最外层(0,0)元素开始由外向里顺时针遍历,确定好第一个元素旋转90度之后的位置后,其实(0,0)后面的其他元素也确定了。 如果我们使用一个单独的二维数组来存储新的值,那么这个题就很好解了。

本题要求必须 原地 旋转,因此需要想想有没有其他办法。

有一个比较灵活的办法,使用两次翻转,首先是上下水平翻转,第二是对角线对称翻转,非常巧妙的解决此题。

本题解题技巧

本题如果不需要在本地旋转,解题思路很容易想到,但是要求不使用另外的数组,需要观察每个元素旋转之后的位置关系。本题理解水平翻转和对角线对称翻转的思想很关键。

编码解决

java 复制代码
class Solution {
    public void rotate(int[][] matrix) {
        int n = matrix.length;
        // 水平翻转
        for (int i = 0; i < n / 2; ++i) {
            for (int j = 0; j < n; ++j) {
                int temp = matrix[i][j];
                matrix[i][j] = matrix[n - i - 1][j];
                matrix[n - i - 1][j] = temp;
            }
        }
        // 主对角线翻转
        for (int i = 0; i < n; ++i) {
            for (int j = 0; j < i; ++j) {
                int temp = matrix[i][j];
                matrix[i][j] = matrix[j][i];
                matrix[j][i] = temp;
            }
        }

    }
}

总结

哈哈,如果是第一次看到这类题目,这题还是有点难度的,我们见过了,以后有类似的题目,可以想下有没有这种有技巧的方式解决。观察转换前后的位置规律非常重要。

相关推荐
问道飞鱼8 分钟前
【Rust编程语言】Rust数据类型全面解析
开发语言·后端·rust·数据类型
Blockbuater_drug14 分钟前
InChIKey: 分子的“化学身份证”,从哈希原理到全球监管合规(2025)
算法·哈希算法·inchikey·rdkit·分子表达·化学信息学
Maxkim30 分钟前
「✍️JS原子笔记 」深入理解JS数据类型检测的4种核心方式
前端·javascript·面试
泉城老铁35 分钟前
目前开源架构需要注意的安全问题
spring boot·后端
橙汁味的风38 分钟前
2EM算法详解
人工智能·算法·机器学习
ZoeGranger39 分钟前
【Spring】IoC 控制反转、DI 依赖注入、配置文件和bean的作用域
后端
马卡巴卡41 分钟前
分库分表数据源ShardingSphereDataSource的Connection元数据误用问题分析
后端
superman超哥42 分钟前
仓颉动态特性探索:反射API的原理、实战与性能权衡
开发语言·后端·仓颉编程语言·仓颉·仓颉语言·仓颉动态特性·反射api
维构lbs智能定位1 小时前
北斗卫星导航定位从核心框架到定位流程详解(一)
算法·北斗卫星导航定位系统
骑着bug的coder1 小时前
第7讲:索引(下)——失效场景与优化实战
后端·mysql