链接: https://leetcode-cn.com/problems/rotate-image/
题面
给定一个 n × n 的二维矩阵 matrix 表示一个图像。请你将图像顺时针旋转 90 度。
你必须在 原地 旋转图像,这意味着你需要直接修改输入的二维矩阵。请不要 使用另一个矩阵来旋转图像。
解法
有两种做法
一种比较trick,先将矩阵上下翻转,再对角翻转,就可以得到结果
另一种就难一点,每次只考虑四个间隔 90 度的位置,如下图所示
实现起来也不好写,找到每次的左上角的顶点,找到正确的式子,完成四个位置的变换
代码
解法一
1 | class Solution { |
解法二
1 | class Solution { |