인프런 커뮤니티 질문&답변
[연속부분 수열1] while문 하나로 작성한 코드인데 혹시 봐주실 수 있을까요?
작성
·
243
0
<html>
<head>
<meta charset="UTF-8">
<title>Two Pointer Algorithm 풀이</title>
</head>
<body>
<script>
function solution(m, arr){
let answer=0, lt = 0, rt = 0;
let sum = 0;
let n = arr.length;
while(rt < n) {
if(sum < m) sum += arr[rt++];
else if(sum > m) sum -= arr[lt++];
else if(sum === m) {
answer++;
sum -= arr[lt++];
}
}
return answer;
}
let a1=[1, 2, 1, 3, 1, 1, 1, 2];
console.log(solution(6, a1));
</script>
</body>
</html>퀴즈
45%나 틀려요. 한번 도전해보세요!
투 포인터 또는 슬라이딩 윈도우 기법이 중첩 반복문보다 효율적인 주된 이유는 무엇일까요?
더 적은 메모리를 사용해서일까요?
코드가 더 짧아져서일까요?
대부분의 경우 O(N) 시간 복잡도를 달성해서일까요?
입력 데이터 크기에 영향을 받지 않아서일까요?
답변 1
0
김태원
지식공유자
안녕하세요^^
아래 입력에 정답이 나오지 않는 코드입니다. 디버그해보세요.
let a1=[1, 1, 1, 1, 1];
console.log(solution(3, a1));





