Leet Code 75 顏色分類

2021-10-07 22:01:41 字數 702 閱讀 1219

用三個指標(p0, p2 和curr)來分別追蹤0的最右邊界,2的最左邊界和當前考慮的元素。

本解法的思路是沿著陣列移動 curr 指標,若nums[curr] = 0,則將其與 nums[p0]互換;若 nums[curr] = 2 ,則與 nums[p2]互換。

class solution:

def sortcolors(self, nums: list[int]) -> none:

"""do not return anything, modify nums in-place instead.

"""p0 = curr = 0

p2 = len(nums) - 1

while curr <= p2:

if nums[curr] == 0:

nums[p0], nums[curr] = nums[curr], nums[p0]

p0 += 1

curr += 1

elif nums[curr] == 2:

nums[p2], nums[curr] = nums[curr], nums[p2]

p2 -= 1

else:

curr += 1

leetcode 75 顏色分類

給定乙個包含紅色 白色和藍色,一共 n 個元素的陣列,原地對它們進行排序,使得相同顏色的元素相鄰,並按照紅色 白色 藍色順序排列。此題中,我們使用整數 0 1 和 2 分別表示紅色 白色和藍色。注意 不能使用 庫中的排序函式來解決這道題。示例 輸入 2,0,2,1,1,0 輸出 0,0,1,1,2,...

leetcode75 顏色分類

給定乙個包含紅色 白色和藍色,一共 n 個元素的陣列,原地對它們進行排序,使得相同顏色的元素相鄰,並按照紅色 白色 藍色順序排列。此題中,我們使用整數 0 1 和 2 分別表示紅色 白色和藍色。注意 不能使用 庫中的排序函式來解決這道題。示例 輸入 2,0,2,1,1,0 輸出 0,0,1,1,2,...

leetcode75 顏色分類

給定乙個包含紅色 白色和藍色,一共 n 個元素的陣列,原地對它們進行排序,使得相同顏色的元素相鄰,並按照紅色 白色 藍色順序排列。此題中,我們使用整數 0 1 和 2 分別表示紅色 白色和藍色。注意 不能使用 庫中的排序函式來解決這道題。示例 輸入 2,0,2,1,1,0 輸出 0,0,1,1,2,...