인프런 커뮤니티 질문&답변
splice를 사용해서 문제를 풀어봤습니다
작성
·
176
0
splice를 사용해서 문제를 풀어봤는데 이렇게 풀어도 될까요..?
function solution(k, arr) {
let max = 0;
for (let i = 0; i < arr.length; i++) {
const arrCopy = [...arr];
const sum = arrCopy.splice(i, k).reduce((a, b) => a + b);
max = Math.max(max, sum);
}
return max;
}퀴즈
45%나 틀려요. 한번 도전해보세요!
투 포인터 또는 슬라이딩 윈도우 기법이 중첩 반복문보다 효율적인 주된 이유는 무엇일까요?
더 적은 메모리를 사용해서일까요?
코드가 더 짧아져서일까요?
대부분의 경우 O(N) 시간 복잡도를 달성해서일까요?
입력 데이터 크기에 영향을 받지 않아서일까요?
답변 1
1
김태원
지식공유자
안녕하세요^^
위에 코드도 reduce가 i저점부터 k번을 반복문처럼 반복하기 때문에 결국에는
for (let i = 0; i < arr.length; i++) {
let sum=0;
for(let j=i; j<i+k; j++){
sum+=arr[j]
과 같은 시간복잡도 O(n^2)입니다. 이런문제는 슬라이딩 윈도우로 하는 습관을 들여 놓는게 좋습니다.





