Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- dynamic programming
- Stack
- Binary Search
- database
- 파이썬
- Method
- Math
- bit manipulation
- Tree
- 자바
- Data Structure
- sorting
- implement
- geometry
- 구현
- Counting
- string
- two pointers
- Class
- Matrix
- 코딩테스트
- array
- simulation
- greedy
- SQL
- hash table
- Number Theory
- 코테
- java
- Binary Tree
Archives
- Today
- Total
코린이의 소소한 공부노트
[LeetCode/Easy] 26. Remove Duplicates from Sorted Array 본문
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을 더해서 개수를 반환한다.
- 느리다.
- 중복값이 여러개가 연속되어있을 경우 한번에 없애지 못한다.
'코딩테스트 풀이 > JAVA' 카테고리의 다른 글
[LeetCode/Medium] 1476. Subrectangle Queries (0) | 2022.08.16 |
---|---|
[LeetCode/Easy] 28. Implement strStr() (0) | 2022.08.12 |
[LeetCode/Easy] 13. Roman to Integer (0) | 2022.08.09 |
[LeetCode/Easy] 9. Palindrome Number (0) | 2022.08.08 |
[LeetCode/Easy] 1. Two Sum (0) | 2022.08.08 |