原地翻转或旋转矩阵

idx, halfLen := len(matrix)-1, len(matrix) / 2 // 记录最后一个元素的下标和边长的一半

// 按对角线反转矩阵
for i := range matrix {
    for j := 0; j < i; j++ {
        matrix[i][j], matrix[j][i] = matrix[j][i], matrix[i][j]
    }
}

// 按竖中轴线反转矩阵
for i := range matrix {
    for j := 0; j < halfLen; j++ {
        matrix[i][j], matrix[i][idx-j] = matrix[i][idx-j], matrix[i][j]
    }
}

// 按横中轴线反转矩阵
for i := 0; i < helfLen; i++ {
    for j := range matrix[i] {
        matrix[idx-i][j], matrix[i][j] = matrix[i][j], matrix[idx-i][j]
    }
}

  

顺时针旋转90:先沿对角线反转矩阵,再沿竖中轴线反转矩阵;
顺时针旋转180:先沿横中轴线反转矩阵,再沿竖中轴线反转矩阵;
顺时针旋转270:先沿对角线反转矩阵,再沿横中轴线反转矩阵;

 

作者:cheless-w
链接:https://leetcode.cn/problems/rotate-image/solution/xuan-zhuan-90180270-by-cheless-w-5b8m/
来源:力扣(LeetCode)

posted @ 2022-07-11 17:23  ☞@_@  阅读(76)  评论(0编辑  收藏  举报