정수 배열 arr와 2차원 정수 배열 queries
이 주어집니다. queries
의 원소는 각각 하나의 query를 나타내며, [s, e, k] 꼴입니다.
각 query마다 순서대로 s ≤ i ≤ e인 모든 i에 대해 i가 k의 배수이면 arr[i]에 1을 더합니다.
i가 현재 조회하고 있는 배열의 값이 아닌 인덱스의 값 진짜 그냥 반복문을 돌면서 바뀌는 i 의 값을 말하는 것 입니다.
위 규칙에 따라 queries
를 처리한 이후의 arr
를 return 하는 solution 함수를 완성해 주세요.
arr
의 길이 ≤ 1,000arr
의 원소 ≤ 1,000,000queries
의 길이 ≤ 1,000arr
의 길이arr | queries | result |
---|---|---|
[0, 1, 2, 4, 3] | [[0, 4, 1],[0, 3, 2],[0, 3, 3]] | [3, 2, 4, 6, 4] |
입출력 예 #1
각 쿼리에 따라 arr
가 다음과 같이 변합니다.
arr |
---|
[0, 1, 2, 4, 3] |
[1, 2, 3, 5, 4] |
[2, 2, 4, 5, 4] |
[3, 2, 4, 6, 4] |
따라서 [3, 2, 4, 6, 4]를 return 합니다.
※ 2023년 04월 27일 입출력 예 설명이 수정되었습니다.
function solution(arr, queries) {
return queries.reduce((acc, cur) => {
const copyArr = [...acc]
const [to, from, val] = cur
return copyArr.map((el, elIdx) => {
if(elIdx >= to && elIdx <= from) {
if(elIdx%val === 0) return el+1
}
return el
})
}, arr)
}