inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

1. 합이 같은 부분집합

똑같이 작성하고 실행하는데 런타임에러가 발생해요

272

홍혁진

작성한 질문수 3

0

import java.util.*;

class Main {
    static String answer = "NO";
    static int n, total = 0;
    boolean flag = false;
    public void dfs(int L, int sum, int[] arr) {
         if(flag) return;
         if(sum > total/2) return;
         if(L == n){
             if(total/2 == sum){
                 answer = "YES";
                 flag = true;
             }
         }else{
             dfs(L + 1, sum + arr[L], arr);
             dfs(L + 1, sum, arr);
         }

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

        n = sc.nextInt();
        int[] arr = new int[n];
        for(int i = 0; i < n; i++){
            arr[i] = sc.nextInt();
            total += arr[i];
        }
        T.dfs(0, 0, arr);
        System.out.println(answer);
    }
}

복습 차원에서 똑같이 코드를 실행하는데 런타임에러가 자꾸 발생하는 이유를 모르겠습니다.

java 코딩-테스트

답변 1

0

인프런 AI 인턴

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

해당 Java 코드에서 런타임 에러의 주된 원인은 main 메서드의 선언 방식에 있습니다. Java에서 main 메서드는 프로그램의 시작점으로서 반드시 public static void로 선언되어야 합니다. 그러나 코드에서 main 메서드는 public void로 선언되어 있어서 정적 메서드로서의 역할을 수행하지 못하고 있습니다.

올바른 main 메서드의 선언 방식은 다음과 같습니다:

public static void main(String[] args) {
    // 여기에 코드를 작성
}

따라서, 코드를 다음과 같이 수정해야 합니다:

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

    n = sc.nextInt();
    int[] arr = new int[n];
    for(int i = 0; i < n; i++){
        arr[i] = sc.nextInt();
        total += arr[i];
    }
    T.dfs(0, 0, arr);
    System.out.println(answer);
}

이렇게 main 메서드를 public static void로 수정하면 프로그램이 올바르게 실행되어 런타임 에러를 해결할 수 있습니다.

안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.

0

21

1

갑자기 채점 사이트가 바뀌었어요

0

29

1

문제 리스트 페이지

0

25

1

채점 사이트 관련 질문드립니다

0

23

1

봉우리 문제 질문입니다

0

79

2

씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?

0

63

0

이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?

0

70

0

가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법

0

67

1

좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ

0

84

2

6-7 강의에서

0

47

1

6-6. 장난꾸러기 질문 있습니다.

0

43

1

강의 수강후 코딩테스트

0

106

1

answer 변수 사용 여부

0

43

1

2중 for문

1

84

2

2-11. 임시반장정하기 (Runtime Error)

0

63

1

혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?

0

69

1

이런 풀이는 어떨까요

0

42

1

자바 스트림 방식의 효율성 질문 드립니다.

0

56

1

알고리즘 자료 구조들..

0

60

1

StringBuilder vs BufferdWriter

0

47

1

원더랜드(프림)

0

48

1

이런 코드는 어떤가요?

0

59

1

bfs 풀이

0

56

1

병합정렬

0

55

1