문제 링크 : https://leetcode.com/problems/remove-duplicates-from-sorted-array/
난이도 : Easy
문제 풀이 :
배열안에 존재하는 중복되는 숫자들을 단 한개씩만 남도록 하는 것이 문제의 핵심이다.
정답을 위한 조건으로는 중복을 제거한 숫자들의 갯수가 몇개인지를 반환하고 nums 배열에 순서대로 재정렬 해야한다.
중복을 제거한 숫자들의 갯수는 Set을 이용하여 간단하게 구할 수 있었다.
문제는 nums 배열의 값을 재정렬 해 주는 것이었는데, 이것도 사실 생각해보니 간단했다.
현재 중복되어 변경할 인덱스를 하나 만든다.
그리고 루프를 돌며 numSet에 존재하지 않는 숫자면 numSet에 넣고 nums 배열의 인덱스 위치의 값을 변경해준 후 인덱스를 증가시킨다.
소스 코드 :
class RemoveDuplicatesFromSortedArray {
fun removeDuplicates(nums: IntArray): Int {
val numSet = mutableSetOf<Int>()
var duplicatedNumIndex = 0
for(i in nums.indices) {
val num = nums[i]
if(!numSet.contains(num)) {
numSet.add(num)
nums[duplicatedNumIndex] = nums[i]
duplicatedNumIndex += 1
}
}
return numSet.size
}
}
후기 :
항상 느끼는 것이지만 문제를 풀고 난 후 다른 사람의 코드를 보면 배우는게 많은 것 같다.
Set을 사용하지 않아도 충분히 풀 수 있었음에도 불구하고 굳이 자료구조를 하나 사용해서 풀게 되었다.
어찌보면 자료구조의 특성에 따라 활용할 수 있는 능력이 있는 것이지만.. 불필요한 상황에서 쓰는 것은 생각이 부족하지 않았나 싶다.
반응형
'Algorithm > Leetcode' 카테고리의 다른 글
LeetCode - Merge Two Sorted Lists (0) | 2020.07.30 |
---|---|
LeetCode - Valid Parentheses (0) | 2020.06.27 |
LeetCode - Longest Common Prefix (0) | 2020.06.27 |
LeetCode - Roman to Integer (0) | 2020.06.27 |
LeetCode - Reverse Integer (0) | 2020.06.27 |