日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

《每日一题》48. Rotate Image 旋转图像

發布時間:2024/5/17 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 《每日一题》48. Rotate Image 旋转图像 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

給定一個 n?×?n 的二維矩陣表示一個圖像。

將圖像順時針旋轉 90 度。

說明:

你必須在原地旋轉圖像,這意味著你需要直接修改輸入的二維矩陣。請不要使用另一個矩陣來旋轉圖像。

示例 1:

給定 matrix = [[1,2,3],[4,5,6],[7,8,9] ],原地旋轉輸入矩陣,使其變為: [[7,4,1],[8,5,2],[9,6,3] ]

示例 2:

給定 matrix = [[ 5, 1, 9,11],[ 2, 4, 8,10],[13, 3, 6, 7],[15,14,12,16] ], 原地旋轉輸入矩陣,使其變為: [[15,13, 2, 5],[14, 3, 4, 1],[12, 6, 8, 9],[16, 7,10,11] ]

宏觀調度

一層一層旋轉,最外面一層按照某種對應規則逐步旋轉,然后由外而內一層一層推進,直到完成。

對應規則也很簡單,對于當前層級,四個四個換,首先把四個角上的元素旋轉,然后往前走一步再旋轉。

Python

class Solution:def rotate(self, matrix: List[List[int]]) -> None:"""Do not return anything, modify matrix in-place instead."""# 當前旋轉邊的左上角和右下角leftTopRow, leftTopCol, rightDownRow, rightDownCol = 0, 0, len(matrix) - 1, len(matrix[-1]) - 1while leftTopRow <= rightDownRow and leftTopCol < rightDownRow:# 按照對應規則逐步旋轉for i in range(rightDownCol - leftTopCol):matrix[leftTopRow][leftTopCol + i], matrix[leftTopRow + i][rightDownCol], \matrix[rightDownRow][rightDownCol - i], matrix[rightDownRow - i][leftTopCol], = \matrix[rightDownRow - i][leftTopCol], matrix[leftTopRow][leftTopCol + i], \matrix[leftTopRow + i][rightDownCol], matrix[rightDownRow][rightDownCol - i]# 完成旋轉后更新層級leftTopRow += 1leftTopCol += 1rightDownRow -= 1rightDownCol -= 1

復雜度分析

  • 時間復雜度:O(N2),外層while循環由于左上角和右下角同時走,N/2,里面for循環長度為矩陣一行的長度,N,所以O(N/2*N)=O(N2/2)=O(N2)
  • 空間復雜度:O(1)
與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的《每日一题》48. Rotate Image 旋转图像的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。