力扣189 旋轉陣列

2021-09-19 09:18:10 字數 904 閱讀 8256

三種解法,解法一很容易想到,後兩種解法比較巧妙,在這裡記錄一下。

每次將陣列每一位向後挪動一位,挪動k%nums.length次(k%nums.length是因為挪動nums.length的倍數次相當於沒有挪動)

//時間複雜度:o(kn)

//空間複雜度:o(1)

class

solution

nums[0]

= last;

last = nums[nums.length -1]

;}}}

① k位為乙個單位進行移動,每次將後k位與前k位交換,使得前k位到達正確的位置。

② 此時,剩餘位置又形成了乙個需要挪動k位的新陣列,重複①,類似乙個遞迴。

//時間複雜度:o(n)

//空間複雜度:o(1)

class

solution}}

}

這個解法是最巧妙的,讓我想我應該想不出來……這也是最符合旋轉陣列這一標題的。

① 將整個陣列翻轉(理解:後移k位其實是將原陣列後k位移動到了最前面,但是前後順序不變。直接翻轉後,已經將後k位移動到最前面了,只是順序相反。)

② 將前k位翻轉

③ 將後n-k位翻轉

//時間複雜度:o(n)

//空間複雜度:o(1)

public

void

rotate

(int[

] nums, int k)

private

void

reverse

(int[

] nums, int start, int end)

}

LeetCode 力扣 189 旋轉陣列 字串

大家覺得寫還可以,可以點讚 收藏 關注一下吧!也可以到我的個人部落格參觀一下,估計近幾年都會一直更新!和我做個朋友吧!給定乙個陣列,將陣列中的元素向右移動 k 個位置,其中 k 是非負數。輸入 1,2,3,4,5,6,7 和 k 3 輸出 5,6,7,1,2,3,4 解釋 向右旋轉 1 步 7,1,...

189 旋轉陣列

給定乙個陣列,將陣列中的元素向右移動 k 個位置,其中 k 是非負數。示例 1 輸入 1,2,3,4,5,6,7 和 k 3 輸出 5,6,7,1,2,3,4 解釋 向右旋轉 1 步 7,1,2,3,4,5,6 向右旋轉 2 步 6,7,1,2,3,4,5 向右旋轉 3 步 5,6,7,1,2,3,...

189 旋轉陣列

給定乙個陣列,將陣列中的元素向右移動 k 個位置,其中 k 是非負數。說明 class solution def rotate self,nums list int k int none do not return anything,modify nums in place instead.n le...