題目:
26. 刪除排序陣列中的重複項
給定乙個排序陣列,你需要在 原地 刪除重複出現的元素,使得每個元素只出現一次,返回移除後陣列的新長度。
不要使用額外的陣列空間,你必須在 原地 修改輸入陣列 並在使用 o(1) 額外空間的條件下完成。
示例 1
:給定陣列 nums =[1
,1,2
], 函式應該返回新的長度 2
, 並且原陣列 nums 的前兩個元素被修改為 1
,2。
你不需要考慮陣列中超出新長度後面的元素。
示例 2
:給定 nums =[0
,0,1
,1,1
,2,2
,3,3
,4],
函式應該返回新的長度 5
, 並且原陣列 nums 的前五個元素被修改為 0,1
,2,3
,4。你不需要考慮陣列中超出新長度後面的元素。
說明:
為什麼返回數值是整數,但輸出的答案是陣列呢?
請注意,輸入陣列是以「引用」方式傳遞的,這意味著在函式裡修改輸入陣列對於呼叫者是可見的。
你可以想象內部操作如下:
// nums 是以「引用」方式傳遞的。也就是說,不對實參做任何拷貝
intlen
= removeduplicates(nums)
;// 在函式裡修改輸入陣列對於呼叫者是可見的。
// 根據你的函式返回的長度, 它會列印出陣列中該長度範圍內的所有元素。
for(
int i =
0; i <
len; i++)
解題思路1:通過count()
函式判斷數字出現的個數,若個數大於一則刪除,最後輸出。
code:
class
solution
:def
removeduplicates
(self, nums: list[
int])-
>
int:
for i in nums[:]
:if nums.count(i)
>1:
nums.remove(i)
return
len(nums)
執行結果:
效率較低,不推薦。
解題思路2:
用set()
函式進行去重,然後再輸出。
code:
class
solution
:def
removeduplicates
(self, nums: list[
int])-
>
int:
nums[:]
=list
(sorted
(set
(nums)))
return
len(nums)
執行結果:
解題思路3:
雙指標問題,乙個指標指向原來的陣列,另乙個指標指向返回的陣列。
code:
class
solution
:def
removeduplicates
(self, nums: list[
int])-
>
int:
old,new =0,
0iflen(nums)==0
:return
0for i in
range
(len
(nums)):
if nums[old]
!= nums[new]
: new +=
1 nums[new]
= nums[old]
old +=
1return new +
1
執行結果: LeetCode 26 刪除排序陣列中的重複項
給定乙個排序陣列,你需要在原地 刪除重複出現的元素,使得每個元素只出現一次,返回移除後陣列的新長度。不要使用額外的陣列空間,你必須在原地修改輸入陣列並在使用 o 1 額外空間的條件下完成。示例 1 給定陣列 nums 1,1,2 函式應該返回新的長度 2,並且原陣列 nums 的前兩個元素被修改為1...
leetcode26 刪除排序陣列中的重複項
給定乙個排序陣列,你需要在原地 刪除重複出現的元素,使得每個元素只出現一次,返回移除後陣列的新長度。不要使用額外的陣列空間,你必須在原地修改輸入陣列並在使用 o 1 額外空間的條件下完成 示例 1 給定陣列 nums 1,1,2 函式應該返回新的長度 2,並且原陣列 nums 的前兩個元素被修改為1...
LeetCode 26刪除排序陣列中的重複項
給定乙個排序陣列,你需要在原地刪除重複出現的元素,使得每個元素只出現一次,返回移除後陣列的新長度。不要使用額外的陣列空間,你必須在原地修改輸入陣列並在使用 o 1 額外空間的條件下完成。示例 1 給定陣列 nums 1,1,2 函式應該返回新的長度2,並且原陣列 nums 的前兩個元素被修改為1,2...