inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

섹션2 5번 소수구하는 문제 질문

210

zzzz8530

작성한 질문수 1

0

import java.util.Scanner;

public class Main {

public int solution(int num) {

int count = 4; //2 ,3, 5, 7 은 미리 포함시켜줌.

for (int i = 2; i <= num; i++) { //1은 소수가 아닌데 if문에 해당하므로 2부터 시작
if (i % 2 != 0 && i % 3 != 0 && i % 5 != 0 && i % 7 != 0) {
count++;
}

}

return count;
}


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


}
}

 

안녕하세요 소수가 2,3,5,7의 배수를 제거하면 남는 수라는 점을 이용해서 2,3,5,7로 나눴을때 하나라도 나머지가 0이면 2,3,5,7중 하나의 배수라는 거니까 나머지가 0이 아닌 경우를 구해서 카운팅하는 방식으로 코드를 짰는데요 (2,3,5,7은 나머지가 0이지만 소수이므로 미리 포함시켜서 count를 4부터 시작했습니다!)

100정도 이하의 숫자 넣었을땐 답이 맞게 나오는데 정답 제출란에서 20000이나 30000같이 큰 수로 테스팅하면 오답이라고 나오네요... 혹시 어떤 점이 문제인지 알 수 있을까요?

 

java 코테 준비 같이 해요!

답변 1

0

안녕안녕안녕안녕

먼저, 소수의 뜻을 정확하게 이해하시는 것이 필요할 듯 보입니다.

 (소수는 2,3,5,7의 배수가 아닌 수가 아니라, 약수가 1과 자기 자신뿐인 자연수입니다.)

 

121의 경우, 약수가 1, 11, 121으로 합성 수 입니다.

2,3,5,7로 나눠도 나머지가 0이 아니지만 이 수는 합성수입니다.

 

제가 볼 때, 작성하신 코드는 10이상의 소수에 10이상의 소수를 곱하는 경우, 모두 잘못 판단할 것 같습니다.

(ex, 121(11 * 11),  143(11 * 13),  169(13 * 13) .... )

 

10이하의 소수를 하드코딩하시는 것이 아닌, 다른 방식으로 접근하셔야 할 것 같습니다.

 

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

0

71

2

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

0

50

1

문제 리스트 페이지

0

43

1

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

0

42

1

봉우리 문제 질문입니다

0

102

2

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

0

73

0

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

0

78

0

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

0

76

1

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

0

94

2

6-7 강의에서

0

53

1

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

0

50

1

강의 수강후 코딩테스트

0

126

1

answer 변수 사용 여부

0

50

1

2중 for문

1

96

2

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

0

67

1

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

0

75

1

이런 풀이는 어떨까요

0

50

1

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

0

62

1

알고리즘 자료 구조들..

0

68

1

StringBuilder vs BufferdWriter

0

53

1

원더랜드(프림)

0

55

1

이런 코드는 어떤가요?

0

66

1

bfs 풀이

0

62

1

병합정렬

0

58

1