시간&메모리 제한
문제
입력&출력
문제풀이
package com.jungol;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class jungol_2811 {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
StringBuilder sb= new StringBuilder();
for (int i = 0; i < 5; i++) {
int temp=Integer.parseInt(st.nextToken());
if(temp==1) {
sb.append("number one"+"\n");
continue;
}
int sq = (int)Math.sqrt(temp);
if(temp<2) {
sb.append("prime number"+"\n");
continue;
}
boolean flag=false;
for (int j = 2; j <= sq; j++) {
if(temp%j==0) {
sb.append("composite number"+"\n");
flag=true;
break;
}
}
if(flag==false) {
sb.append("prime number"+"\n");
continue;
}
}
System.out.println(sb);
}
}
- 이 문제의 경우는 소수인지? 합성수인지? 둘다 아닌지를 구분하는 문제입니다.
- 둘다 아닌 경우는 1 밖에 없습니다. 따라서 1에 대한 조건문으로 예외 처리를 해주면 됩니다.
- 소수를 구하는 방법 중에 범위를 제곱수 범위까지만 구하면 됩니다. 예를 들면 25라는 수일때 5까지만 구하면 됩니다.
'Algorithm > 정올 알고리즘' 카테고리의 다른 글
정올_1740 소수(자바) / 수학2 (0) | 2021.06.30 |
---|---|
정올_1370 회의실 배정(자바) / 탐욕 알고리즘 (0) | 2021.06.30 |
정올_1214 히스토그램(자바) / 자료구조 (0) | 2021.06.29 |
정올_1009 각 자리 수의 역과 합(자바) / 수학2 (0) | 2021.06.28 |
정올_1002 최대공약수, 최소공배수(자바) / 수학1 (0) | 2021.06.27 |