자바/코드트리
[코드트리] 공약수 - 자바(Java)
Jakorithm
2023. 12. 30. 00:47
728x90
문제
코드트리 | 코딩테스트 준비를 위한 알고리즘 정석
국가대표가 만든 코딩 공부의 가이드북 코딩 왕초보부터 꿈의 직장 코테 합격까지, 국가대표가 엄선한 커리큘럼으로 준비해보세요.
www.codetree.ai
자연수 n개가 주어졌을 때, 이 자연수의 모든 공약수를 구하는 프로그램을 작성해 보세요.
코드
첫 번째 줄에 n이 주어지고, 두 번째 줄에는 공약수를 구해야 하는 자연수 n개가 공백(" ")으로 구분되어 주어진다.
- n은 2 또는 3
- 1 <= 자연수 <= 100,000
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int n = Integer.parseInt(br.readLine());
StringTokenizer st = new StringTokenizer(br.readLine());
// 입력받은 자연수 배열에 담기
int[] target = new int[n];
for (int i = 0; i < n; i++) {
target[i] = Integer.parseInt(st.nextToken());
}
// 최대공약수 구하기
int gcd = target[0];
for (int i = 1; i < target.length; i++) {
gcd = calculateGcd(gcd, target[i]);
}
// 최대 공약수의 약수 출력하기
for (int i = 1; i <= gcd; i++) {
if (gcd % i == 0) {
System.out.println(i);
}
}
}
// 최대공약수 구하는 메서드(유클리드 호제법)
private static int calculateGcd(int a, int b) {
int x = Math.max(a, b);
int y = Math.min(a, b);
while (x % y != 0) {
int r = x % y;
x = y;
y = r;
}
return y;
}
}
- 유클리드 호제법을 활용하여 n개의 자연수에 대한 최대 공약수를 구한다.
- 최대 공약수의 모든 약수를 출력한다.
728x90