자바스크립트
[JavaScript] 프로그래머 수열과 구간 쿼리 4
코딩하는둥이
2024. 4. 25. 21:01
문제 설명
정수 배열 arr와 2차원 정수 배열 queries이 주어집니다. queries의 원소는 각각 하나의 query를 나타내며, [s, e, k] 꼴입니다.
각 query마다 순서대로 s ≤ i ≤ e인 모든 i에 대해 i가 k의 배수이면 arr[i]에 1을 더합니다.
위 규칙에 따라 queries를 처리한 이후의 arr를 return 하는 solution 함수를 완성해 주세요.
입출력 예
arr | queries | result |
[0, 1, 2, 4, 3] | [[0, 4, 1],[0, 3, 2],[0, 3, 3]] | [3, 2, 4, 6, 4] |
코드
const solution = (arr, queries)=>{
return queries.reduce((acc,[s,e,k]) => {
for(i = s; i <= e; i++){
if(i % k == 0) acc[i]++;
}
return acc;
},[...arr]);
}
설명
1) reduce 함수를 사용하여 queries 배열을 순회합니다.
2) 각 쿼리 [s, e, k]에서 시작 s부터 종료 인덱스 e까지 반복합니다.
3) 현재 인덱스 i가 k로 나누어 떨어질 때 acc[i]가 증가됩니다.
4) 누적 결과 acc 반환합니다.