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

ghkddlscks19님의 프로필 이미지
ghkddlscks19

작성한 질문수

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

4. 연속부분수열(복합적 문제)

연속부분수열

작성

·

170

0

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Scanner;

public class Main {

    public int solution(int n, int m, int arr[]) {
        int answer = 0;
        int sum = 0;
        int lt = 0;
        int rt = 1;

        // 초기 합 설정
        sum += arr[lt] + arr[rt];
        while (rt < n - 1) {
            if (sum < m) {
                sum += arr[++rt];
            } else if (sum == m) {
                answer++;
                sum -= arr[lt++];
            } else {
                sum -= arr[lt++];
            }
        }

        // while문에서 rt가 마지막 인덱스일 때 합은 검증을 못해서 검증 로직 추가
        if (sum == m) answer++;


        return answer;

    }

    public static void main(String[] args) {
        Main T = new Main();
        Scanner sc = new Scanner(System.in);

        int n = sc.nextInt();
        int m = sc.nextInt();


        int arr[] = new int[n];

        for (int i = 0; i < n; i++) {
            arr[i] = sc.nextInt();
        }

        System.out.println(T.solution(n, m, arr));

    }
}

이 코드가 효율적인 코드인지 궁금해서 질문드립니다!!

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. ghkddlscks19님.

연속부분수열 문제에 대한 코드 효율성에 관한 귀하의 질문에 답하기 위해 기존에 유사한 질문이 있었는지 살펴보았습니다.

제가 찾은 다음 답변들은 연속부분수열 문제와 관련된 코드 효율성 및 개선 방안에 대한 공유와 교정을 포함하고 있습니다. 이 답변들이 귀하의 코드에 대한 효율성을 평가하고 이해를 높일 수 있는 참고 자료로 활용될 수 있을 것입니다.

이러한 게시글에서는 Two Pointers Algorithm(두 포인터 알고리즘)을 사용하여 연속부분수열을 찾고 합산이 특정 값에 도달할 때 카운트하는 방법을 논의하고 있습니다. 특히 연속부분수열 문제는 주어진 수열에서 연속적인 부분 수열의 합이 특정 값에 도달하는 경우의 수를 세는 문제로, 투 포인터 알고리즘을 사용하여 효율적으로 해결할 수 있습니다. 질문자님이 제공한 코드도 이러한 접근 방식을 사용하여 해결하고 있는 것으로 보입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

ghkddlscks19님의 프로필 이미지
ghkddlscks19

작성한 질문수

질문하기