inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

6. 뒤집은 소수

다른 분들의 질문을 보면 Math.sqrt, num / 2 하는 것을 볼 수 있는데...

418

australialove19

작성한 질문수 53

0

저렇게 하시는 이유가 뭔지 궁금합니다 ㅠㅠ

구글링해보았을 때도 비슷한 케이스를 볼 수 있었는데 정확한 이유를 잘 모르겠습니다 ㅠㅠ

코테 준비 같이 해요! java

답변 1

0

김태원

안녕하세요^^

그냥 수학지식입니다.

어떤 숫자가 소수인지 확인해 보려면 2부터 그 숫자의 제곱근까지에서 약수가 없으면 소수입니다.

만약 36이 소수인지 알고싶으면 2부터 6까지에서 36의 약수가 존재하는지 확인하면 됩니다.

36의 약수들을 살펴보면 아래와 같습니다.

36 = 1 * 36

36 = 2 * 18

36 = 3 * 12

36 = 4 * 9

36 = 6 * 6

36의 약수들입니다. 2부터 6까지만 확인하면 그 짝궁들은 자연스럽게 존재유무가 확인되는 거죠.

num / 2를 하는 이유는 1와 자기자신을 빼면 2부터 자기자신의 절반까지에서 약수는 존재합니다.

위에 36같은 경우 1 36 을 빼면 약수는 2부터 18까지에서만 존재합니다. 36 = 2 * 18

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

0

41

2

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

0

37

1

문제 리스트 페이지

0

31

1

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

0

25

1

봉우리 문제 질문입니다

0

88

2

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

0

66

0

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

0

72

0

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

0

68

1

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

0

85

2

6-7 강의에서

0

48

1

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

0

46

1

강의 수강후 코딩테스트

0

111

1

answer 변수 사용 여부

0

48

1

2중 for문

1

85

2

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

0

63

1

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

0

70

1

이런 풀이는 어떨까요

0

46

1

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

0

61

1

알고리즘 자료 구조들..

0

64

1

StringBuilder vs BufferdWriter

0

50

1

원더랜드(프림)

0

51

1

이런 코드는 어떤가요?

0

62

1

bfs 풀이

0

58

1

병합정렬

0

58

1