[JS] 기초 알고리즘 - 같은 숫자는 싫어 | Lv. 1 (77%)
- 알고리즘
- 2024. 7. 8.
문제
배열 arr가 주어집니다. 배열 arr의 각 원소는 숫자 0부터 9까지로 이루어져 있습니다. 이때, 배열 arr에서 연속적으로 나타나는 숫자는 하나만 남기고 전부 제거하려고 합니다. 단, 제거된 후 남은 수들을 반환할 때는 배열 arr의 원소들의 순서를 유지해야 합니다. 예를 들면,
- arr = [1, 1, 3, 3, 0, 1, 1] 이면 [1, 3, 0, 1] 을 return 합니다.
- arr = [4, 4, 4, 3, 3] 이면 [4, 3] 을 return 합니다.
배열 arr에서 연속적으로 나타나는 숫자는 제거하고 남은 수들을 return 하는 solution 함수를 완성해 주세요.
코드
function solution(arr)
{
var answer = arr.filter((cur, idx, array) => {
return cur != array[idx+1]
})
return answer
}
console.log(solution([1,1,3,3,0,1,1])) // [1, 3, 0, 1]
- `filter()` 내에서 현재 요소와 다음 요소(idx+1)의 값을 비교
- 값이 다를 경우(중복이 아닌 경우) 요소 반환
💡 filter() 함수 알아보기
한줄챌린지
화살표 함수를 이용해서 한 줄로 줄여보자
const solution = arr => arr.filter((cur, idx, array) => cur != array[idx+1]);
💡화살표 함수 알아보기
'알고리즘' 카테고리의 다른 글
[JS] 기초 알고리즘 - 최소직사각형 | Lv. 1 (74%) (0) | 2024.07.09 |
---|---|
[JS] 기초 알고리즘 - 예산 | Lv. 1 (76%) (0) | 2024.07.08 |
[JS] 기초 알고리즘 - 없는 숫자 더하기 | Lv. 1 (86%) (0) | 2024.07.02 |
[JS] 문자열을 정수로 바꾸기 | 이상한 자바스크립트 (0) | 2024.06.28 |
[JS] 기초 알고리즘 | 자연수 뒤집어 배열로 만들기 (0) | 2024.06.28 |