일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- kotiln functional interface
- nodejs rabbitmq
- ipfs singletone
- spring mongodb switch
- kotiln const val
- 안정해시
- Spring ipfs
- java 백준 1509
- java 1509
- javav 1676
- spring mongodb
- 백준 2252 줄세우기
- spring mongoTemplate
- Java Call By Refernce
- kotiln const
- rabbitmq 싱글톤
- mongodb lookup
- go
- spring mongoTemplate switch
- 자바 1676
- 백준 연결요소 자바
- ipfs bean
- 자바 백준 팩토리얼 개수
- 전략 패턴이란
- 백준 특정한 최단 경로
- java 팩토리얼 개수
- 백준 1504 java
- 익명 객체 @transactional
- java 1238
- java 파티
Archives
- Today
- Total
공부 흔적남기기
프로그래머스 소수찾기 본문
728x90
반응형
class Solution {
public int solution(int n) {
//보통 소수찾는 알고리즘에서는 에라토스네스체의 방식이 사용됨 소수 찾을 땐 이게 짱임
int answer = eratosneSosu(n);
return answer;
}
//에라토스네스체 구현 방법
//2부터 n의 제곱근까지 돌면서 자신의 을 제외하고 자신의 배수들 다 지우기
public int eratosneSosu(int n){
int arr[] = new int[n+1];
//일단 1부터 정해진 곳까지 전부 수를 채운 배열을 만듬
for(int i=1; i<=n; i++){
arr[i] = i;
}
//소수는 2부터 시작하므로 i=2
//n의 제곱근까지 배열을 돌면 다 지워짐
for(int i =2; i<=Math.sqrt(n); i++){
//이미 지워졌다면 for문 넘기기
if(arr[i] == 0){
continue;
}
//지워지지 않았다면 i의 배수들 다지우기
//i*i부터 시작하는 이유는
//i*1, i*2 ... 은 1*i 2*i 를 통해 이미 지워졌기 떄문이다.
for(int j = i*i; j<=n; j+=i){
arr[j] =0;
}
}
int count = 0;
for(int i=2; i<=n; i++){
if(arr[i] != 0){
count++;
}
}
return count;
}
}
문제: https://programmers.co.kr/learn/courses/30/lessons/12921
코딩테스트 연습 - 소수 찾기
1부터 입력받은 숫자 n 사이에 있는 소수의 개수를 반환하는 함수, solution을 만들어 보세요. 소수는 1과 자기 자신으로만 나누어지는 수를 의미합니다. (1은 소수가 아닙니다.) 제한 조건 n은 2이상
programmers.co.kr
728x90
반응형
'코테 > 프로그래머스' 카테고리의 다른 글
프로그래머스 체육복 (0) | 2022.01.17 |
---|---|
프로그래머스 실패율 (0) | 2022.01.17 |
프로그래머스 나머지가 1이 되는 수 찾기 (0) | 2022.01.16 |
프로그래머스 K번째수 (0) | 2022.01.16 |
프로그래머스 최대공약수와 최소공배수 (0) | 2022.01.16 |