# Description
Given an integer array nums
sorted in non-decreasing order, remove some
duplicates in-place such that each unique element appears at most
twice. The relative order of the elements should be kept the
same.
Since it is impossible to change the length of the array in some languages, you must instead have the result
be placed in the first part of the array nums
. More formally, if there are
k
elements after removing the duplicates, then the first k
elements of
nums
should hold the final result. It does not matter what you leave beyond the
first k
elements.
Return k
after placing the final result in the first k
slots of nums
.
Do not allocate extra space for another array. You must do this by modifying the input array in-place with O(1) extra memory.
Custom Judge:
The judge will test your solution with the following code:
|
|
If all assertions pass, then your solution will be accepted.
Example 1:
|
|
Example 2:
|
|
Constraints:
1 <= nums.length <= 3 * 104
-104 <= nums[i] <= 104
nums
is sorted in non-decreasing order.
# Approach 1
# 풀이
idx = 1
을 선언하여 1번째 인덱스부터 추가될 수를 구합니다.
같은 수가 2개까지 허용되기에, 추가될 수가 두번째 수인지 아닌지 구분해 줄 not_twice
변수를 선언했습니다.
idx번째 인덱스에 수가 추가되어야 할 경우는 두 가지입니다.
- i번째 수와 i-1번째 수가 같지 않은 경우
- i번째 수와 i-1번째 수가 같으며, i번째 수가 두번째 수인 경우.
이에 대한 조건문을 작성하며 풀이했습니다.
# 코드
|
|
# Approach 2
코드 제출 후 Solutions을 참고하며 다른 코드를 참고했습니다.
# 풀이
수에 대해 한번은 중복이 허용되기에, 1번째 인덱스까지는 기존의 수가 들어가면 됩니다.
이후 i번째 수와 idx-2번째 수를 비교한다면, 같은 수가 2번을 초과하는 경우를 처리할 수 있습니다.
따라서 idx=2
, i=2
부터 i번째 수가 idx-2와 같지 않은 경우에만 idx번째 인덱스에 수를 추가합니다.
# 코드
|
|