코린이의 소소한 공부노트

[LeetCode/Easy] 26. Remove Duplicates from Sorted Array 본문

코딩테스트 풀이/JAVA

[LeetCode/Easy] 26. Remove Duplicates from Sorted Array

무지맘 2022. 8. 10. 22:00

1. Input

1) 오름차순으로 정렬된 int 배열 nums

 

2. Output

1) 중복이 제거된 후 남은 숫자들의 개수 k

2) 중복이 제거된 숫자들은 nums의 앞쪽에 배치시킴

3) 뒷쪽을 채울 값은 신경쓰지 않음

4) k를 정답 계산기에 넣고 답이 맞는지 확인할 예정

  - nums = {0, 0, 1, 2, 2}라고 한다면, 중복이 제거된 후에는 nums = {0, 1, 2, _, _}가 되므로 k = 3이 된다

  - 이를 정답 계산기에 넣었을 때, 0번째부터 k-1번째까지 nums[i] == answer[i]인지 확인

 

3. Constraint

1) nums를 복사해서 이용하는 등 메모리를 더 사용하는 것은 금지 (O(1) extra memory)

2) 1 <= nums.length <= 3 * 104

3) -100 <= nums[i] <= 100

 

4. Example

Input: nums = {1,1,2}
Output: 2

이때의 nums = {1,2,_}

 

5. Code

int k=nums.length-1;
for(int i=0 ; i<nums.length-1 ; i++){            
    if(i==k)
        break;
    if(nums[i]==nums[i+1]){
        for(int j=i+1 ; j<k ; j++){
            nums[j] = nums[j+1];
        } // for j
        k--;
    }// if
}// for i
return k+1;

  - 중복값이 확인될때마다 배열 값을 1칸씩 앞으로 땡기고, k값도 1씩 줄여나간다.

  - i == k가 되면 for문을 중단한다.

  - k는 중복을 없앤 값의 마지막 인덱스가 되므로, 1을 더해서 개수를 반환한다.

  - 느리다.

  - 중복값이 여러개가 연속되어있을 경우 한번에 없애지 못한다.