일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- SECS
- spring boot
- 백준
- spotify
- java
- CS
- regression
- linux
- 스포티파이
- Spring
- SECS-II
- Baekjoon
- SECS/GEM
- 자바
- 회원가입
- c
- SWEA
- Gem
- python
- 파이썬
- programmers
- 회귀
- 프로그래머스
- SW Expert Academy
- Spotify Api
- modern c++
- Computer Science
- C++
- Spring JPA
- MYSQL
Archives
- Today
- Total
비버놀로지
[Programmers 프로그래머스] 12921 소수 찾기 본문
728x90
programmers.co.kr/learn/courses/30/lessons/12921
입력값의 소수를 찾는 문제이다.
큰 숫자의 소수를 찾을때에는 root를 이용해야 시간초과가 나지 않는다.
그래서 root값을 이용을 해서 for문을 돌면서 소수인 값을 false로 만들어 주고, false의 수를 세어주어 값을 출력한다.
import java.util.Arrays;
class Solution {
public int solution(int n) {
int answer=0;
boolean []sosu=new boolean[n+1];
Arrays.fill(sosu, true);
int root=(int)Math.sqrt(n);
for (int i = 2; i <= root; i++) {
if(sosu[i]==true) {
for (int j = i; i*j <= n; j++) {
sosu[i*j]=false;
}
}
}
for (int i = 2; i <=n; i++) {
if(sosu[i]==true) {
answer++;
}
}
return answer;
}
}
728x90
'ALGORITM > JAVA' 카테고리의 다른 글
[Programmers 프로그래머스] 12925 문자열을 정수로 바꾸기 (0) | 2021.01.07 |
---|---|
[Programmers 프로그래머스] 12922 수박수박수박수박수박수? (0) | 2021.01.07 |
[Programmers 프로그래머스] 12919 서울에서 김서방 찾기 (0) | 2021.01.07 |
[Programmers 프로그래머스] 12918 문자열 다루기 기본 (0) | 2021.01.07 |
[Programmers 프로그래머스] 12917 문자열 내림차순으로 배치하기 (0) | 2021.01.07 |
Comments