inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Giới thiệu về giải quyết vấn đề thuật toán Java: Chuẩn bị cho các bài kiểm tra mã hóa

20강 소수 에라토스테네스의 체 런타임 에러가 뜹니다

43

bsb5028

34 câu hỏi đã được viết

0

강사님 풀이대로하고 코딩채첨을 했더니 런타임 에러가 뜨네요

import java.util.Scanner;

public class Main {

    public int solution(int n) {
        int answer = 0;
        int[] isPrime = new int[n + 1];
        for (int i = 2; i <= n; i++) {
            if (isPrime[i] == 0) {
                answer++;
                for (int j = i * i; j <= n; j += i) {
                    isPrime[j] = 1;
                }
            }
        }
        return answer;
    }

    public static void main(String[] args) {
        Main m = new Main();
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        System.out.println(m.solution(n));
    }
}

이렇게 하고 그대로 복붙했더니 런타임 에러가 뜹니다.

java 코딩-테스트

Câu trả lời 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. 커디널스님.

당신의 질문은 “자바(Java) 알고리즘 문제풀이 입문: 코딩테스트 대비” 강의의 20강, 소수(에라토스테네스의 체) 문제에 관한 런타임 에러 관련입니다.

런타임 에러가 발생하는 주된 이유는 for (int j = i * i; j <= n; j += i) 부분에서 i * i에 의해 overflow가 발생할 가능성이 있기 때문입니다. 예를 들어, i의 값이 매우 클 경우 i * i는 int 범위를 초과할 수 있습니다. 이를 방지하기 위해 다음과 같이 수정할 수 있습니다:

for (long j = (long) i * i; j <= n; j += i) {
    isPrime[(int) j] = 1;
}

여기서 jlong 타입으로 선언하여 곱셈에 의해 발생할 수 있는 overflow를 방지하고, isPrime 배열의 인덱스에 int로 형변환하여 접근합니다.

이와 관련된 유사한 질문으로는 소수 판단시 j값 설정과 runtime오류 문의와 같은 문제가 있습니다. 질문에서 제기된 내용과 해결책을 참조하여 문제를 해결해 보시기 바랍니다.

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

봉우리 문제 질문입니다

0

70

2

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

0

57

0

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

0

65

0

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

0

63

1

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

0

77

2

6-7 강의에서

0

43

1

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

0

39

1

강의 수강후 코딩테스트

0

99

1

answer 변수 사용 여부

0

38

1

2중 for문

1

79

2

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

0

57

1

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

0

62

1

이런 풀이는 어떨까요

0

38

1

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

0

50

1

알고리즘 자료 구조들..

0

54

1

StringBuilder vs BufferdWriter

0

42

1

원더랜드(프림)

0

41

1

이런 코드는 어떤가요?

0

53

1

bfs 풀이

0

50

1

병합정렬

0

50

1

26강 임시반장 정하기에서 질문이 있습니다

0

36

1

이번달말에 완강 후 공부 방향

0

64

1

제가 이런 코테가 처음인데 공부방법을..ㅠ

1

102

1

peek() 메소드 사용한 문제풀이

0

41

1