일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- m1 docker install
- 나누어 떨어지는 숫자 배열 java
- 핸즈온 머신러닝
- docker remove
- 가운데 글자 가져오기 자바
- 트리의 지름 java
- codeup 1020 자바
- docker 완전 삭제
- 프로그래머스 가운데 글자 가져오기 파이썬
- 최단 경로 알고리즘
- 빅데이터분석기사
- 코드업 1020 java
- 가운데 글자 가져오기 java
- 프로그래머스 나누어 떨어지는 숫자 배열 파이썬
- 최소 스패닝 트리 자바
- codeup 1020 java
- 가운데 글자 가져오기 python
- 청년 Ai Big Data 아카데미
- 청년 AI Big Data 아카데미 13기
- 프로그래머스 가운데 글자 가져오기 python
- docker 삭제
- 트리의 지름 자바
- 빅분기실기
- m1 docker
- 최소 스패닝 트리
- 프로그래머스 가운데 글자 가져오기 자바
- 가운데 글자 가져오기 파이썬
- 코드업 1020 자바
- 나누어 떨어지는 숫자 배열 python
- 프로그래머스 나누어 떨어지는 숫자 배열 자바
- Today
- Total
NineTwo meet you
[프로그래머스/파이썬/자바] 소수 찾기 본문
문제 & 제한사항 & 예제
문제 설명
1부터 입력받은 숫자 n 사이에 있는 소수의 개수를 반환하는 함수, solution을 만들어 보세요.
소수는 1과 자기 자신으로만 나누어지는 수를 의미합니다.
(1은 소수가 아닙니다.)
제한 조건
- n은 2이상 1000000이하의 자연수입니다.
입출력 예
n | result |
10 | 4 |
5 | 3 |
입출력 예 설명
입출력 예 #1
1부터 10 사이의 소수는 [2,3,5,7] 4개가 존재하므로 4를 반환
입출력 예 #2
1부터 5 사이의 소수는 [2,3,5] 3개가 존재하므로 3를 반환
풀이
<start부터 end까지의 수 중 소수 구하기>
※아래 설명 코드는 자바로 설명했습니다.
1. 기본 방법
start부터 end까지 수를 살펴본다. (i 인덱스)
해당 값을 2부터 i-1까지의 수를 나눠보며 나눠지면 합성수, 끝까지 안 나눠지면 소수로 판단한다.
시간 복잡도는 n**2
class Solution {
public int solution(int start, int end) {
int sw = 1;
for(int i = start; i <= end; i++){
sw = 1;
if(i == 1){
sw = 0;
continue;
}
for(int j = 2; j < i ; j++){
if(i%j == 0){
sw = 0;
break;
}
}
if(sw == 1){
System.out.println(i);
}
}
}
}
2. 제곱 근 이용
1번 방법과의 차이점은 j를 2부터 i-1까지의 수가 아닌 2부터 루트 j까지만 살펴보며 소수인지를 판단한다.
class Solution {
public int solution(int start, int end) {
int sw = 1;
for(int i = start; i <= end; i++){
sw = 1;
if(i == 1){
sw = 0;
continue;
}
int root = (int) Math.sqrt(i)+1;
for(int j = 2; j < root ; j++){
if(i%j == 0){
sw = 0;
break;
}
}
if(sw == 1){
System.out.println(i);
}
}
}
3. 에라토스테네스의 체
2부터 end까지 살펴보면서 각각의 해당 수의 배수를 지워가는 방식이다.
class Solution {
public int solution(int start, int end) {
boolean visited[] = new boolean[end+1];
for(int i = 2; i <= end; i++){
visited[i] = true;
}
for(int i = 2; i <= end; i++){
if(visited[i] == false){
continue;
}else{
for(int j = i*2; j <= end ; j+=i){
visited[j] = false;
}
}
}
for(int i = 2; i <= end; i++){
if(visited[i]){
System.out.println(i);
}
}
}
}
코드
'프로그래밍 문제 > 프로그래머스' 카테고리의 다른 글
[프로그래머스/파이썬/자바] 정수 제곱근 판별 (0) | 2020.08.28 |
---|---|
[프로그래머스/파이썬/자바] 약수의 합 (0) | 2020.08.28 |
[프로그래머스/파이썬/자바] 문자열 내림차순으로 배치하기 (0) | 2020.08.28 |
[프로그래머스/파이썬/자바] 문자열 내 마음대로 정렬하기 (0) | 2020.08.28 |
[프로그래머스/파이썬/자바] 크레인 인형뽑기 게임 (0) | 2020.08.28 |