자바스크립트

[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 반환합니다.