인프런 커뮤니티 질문&답변

제투님의 프로필 이미지
제투

작성한 질문수

자바스크립트 알고리즘 문제풀이 입문(코딩테스트 대비)

3. 연속부분수열1(Two Pointers Algorithm)

안녕하세요 선생님 풀이 리뷰 부탁드립니다.

작성

·

136

0

sum이 주어진 값(m)을 초과하였을 때 sum에서 lt(제 코드에서는 start) 인덱스 값을 빼주는 것이 아니라 포인터와 sum을 초기화하면서 진행하였는데 이런 코드는 효율성이 떨어질까요? 또한 제 코드에 대한 반례가 있는지도 궁금합니다.

 

<script>
        function solution(m, arr) {
            let answer = 0;
            let start = end = 0;
            let sum = 0;

            while (start < arr.length) {
                while (end < arr.length && sum < m) {
                    sum += arr[end++];
                }
                if (sum === m) {
                    answer++;
                }
                start++;
                end = start;
                sum = 0;
            }
            return answer;
        }

        let a = [1, 2, 1, 3, 1, 1, 1, 2];
        console.log(solution(6, a));
    </script>

답변 1

0

김태원님의 프로필 이미지
김태원
지식공유자

안녕하세요^^

위에 코드는 시간복잡도가 O(n^2)입니다.  영상의 방법이 O(n)으로 효율성이 더 좋습니다. 참고하시기 바랍니다.

제투님의 프로필 이미지
제투

작성한 질문수

질문하기