알고리즘/백준

백준 2609번 최대공약수와 최소공배수 자바 Java (☆공부 242일차)

김발자~ 2023. 3. 29. 09:56
반응형

2609 최대공약수와 최소공배수

https://www.acmicpc.net/problem/2609

 

2609번: 최대공약수와 최소공배수

첫째 줄에는 입력으로 주어진 두 수의 최대공약수를, 둘째 줄에는 입력으로 주어진 두 수의 최소 공배수를 출력한다.

www.acmicpc.net

 

 

 


백준 2609번 문제 최대공약수와 최소공배수


문제


 
시간 제한 메모리 제한 제출 정답 맞힌 사람 정답 비율
1 초 128 MB 89488 51695 41931 58.108%

문제

두 개의 자연수를 입력받아 최대 공약수와 최소 공배수를 출력하는 프로그램을 작성하시오.

입력

첫째 줄에는 두 개의 자연수가 주어진다. 이 둘은 10,000이하의 자연수이며 사이에 한 칸의 공백이 주어진다.

출력

첫째 줄에는 입력으로 주어진 두 수의 최대공약수를, 둘째 줄에는 입력으로 주어진 두 수의 최소 공배수를 출력한다.

예제 입력 1

24 18

예제 출력 1

6
72
 

 

 


과정 생각해보기


 

https://gimbalja.tistory.com/173

 

공부 94일차: 백준 2609번 최대공약수와 최소공배수 자바 java

2609 최대공약수와 최소공배수 https://www.acmicpc.net/problem/2609 2609번: 최대공약수와 최소공배수 첫째 줄에는 입력으로 주어진 두 수의 최대공약수를, 둘째 줄에는 입력으로 주어진 두 수의 최소 공배

gimbalja.tistory.com

 
문제 몇 개 건너뛰고, 4달 전에 풀었던 문제

 

 
유클리드 호제법 과정 설명은 아래 정리해두었다
 
 

정답 인정 코드


 
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
32
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));
        StringTokenizer st = new StringTokenizer(br.readLine());
        StringBuilder sb = new StringBuilder();
        
        int a = Integer.parseInt(st.nextToken());
        int b = Integer.parseInt(st.nextToken());
        int gcd = gcd(a, b);
        
        sb.append(gcd).append("\n").append(a*b/gcd);    // ★
    
        System.out.println(sb);
        br.close();
    }
 
    // ★
    static int gcd(int a, int b) {
        if(b == 0) {
            return a;
        }
        
        return gcd(b, a%b);
    }
}
 
cs

 

 


이전엔 sb를 만들지 않았었는데 메모리랑 시간은 거의 똑같다

반응형