인프런 커뮤니티 질문&답변
풀이 질문드립니다.
작성
·
123
0
저는 이렇게 짰는데 혹시 문제가 될만한 사항이 있을까요??
function solution(arr, m) {
let answer = 0;
let p1 = 0;
let p2 = 1;
let sum = 0;
while (p1 < arr.length) {
sum += arr[p1++];
if (sum >= m) {
(sum === m) && answer++;
sum = 0;
p1 = p2++;
}
}
return answer;
}
input = [5, 2, 3, 8, 9, 1, 4, 1, 1];
console.log(solution(input, 10));퀴즈
45%나 틀려요. 한번 도전해보세요!
투 포인터 또는 슬라이딩 윈도우 기법이 중첩 반복문보다 효율적인 주된 이유는 무엇일까요?
더 적은 메모리를 사용해서일까요?
코드가 더 짧아져서일까요?
대부분의 경우 O(N) 시간 복잡도를 달성해서일까요?
입력 데이터 크기에 영향을 받지 않아서일까요?
답변 1
2
김태원
지식공유자
안녕하세요^^
위에 코드는 p1이 매번 p2지점부터 새로 시작하는 결국에는 시간복잡도가 O(n^2)인 이중for문과 다를게 없습니다.
이 영상의 핵심은 투포인터 알고리즘으로 시간복잡도를 O(n)으로 하는것입니다.





