티스토리 뷰

알고리즘/백준

[BAEJOON] 1934 최소공배수

응애~ 개발자 2022. 9. 21. 16:01
728x90
반응형

문제 요약

  • 알고리즘 분류: 유클리드 호제법
  • 난이도: Bronze1
  • 문제내용:
    • 테스트케이스 개수만큼 두 수의 최소 공배수를 구하면 된다.
  • 사이트: https://www.acmicpc.net/problem/1934
 

1934번: 최소공배수

두 자연수 A와 B에 대해서, A의 배수이면서 B의 배수인 자연수를 A와 B의 공배수라고 한다. 이런 공배수 중에서 가장 작은 수를 최소공배수라고 한다. 예를 들어, 6과 15의 공배수는 30, 60, 90등이 있

www.acmicpc.net

문제풀이

  1. 위 문제는 유클리드 호제법으로 푸는 방법이다. 유클리드 호제법에 내한 내용은 아래의 사이트에 참조 하면된다

[알고리즘/이론] - 유클리드 호제법(Euclidean algorithm)

 

유클리드 호제법(Euclidean algorithm)

이론 1. 유클리드 호제법이란? 두 개의 정수 혹은 다수의 자연수에서 최대공약수를 구하는 알고리즘이다. 원리는 두 수가 서로 나눠서 나머지를 구한다. 만약 나머지가 0이면 그 수가 최대 공약

jih3508.tistory.com

 

CODE

Python

import sys
input = sys.stdin.readline

def Euclid(x, y):
    print(x, y)
    if x % y == 0:
        return y
    return Euclid(y, x % y)

for _ in range(int(input())):
    A, B = map(int, input().split())
    print(A * B // Euclid(A, B))

Java

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 T = Integer.parseInt(br.readLine());
		StringTokenizer st;
		int A, B;
		for(int i = 0; i < T; i++) {
			st = new StringTokenizer(br.readLine());
			A = Integer.parseInt(st.nextToken());
			B = Integer.parseInt(st.nextToken());
			System.out.println(A * B / Euclid(A, B));
						
		}
		
	}
	
	public static int Euclid(int x, int y) {
		if (x % y == 0) {
			return y;
		}else {
			return Euclid(y, x % y);
		}
		
	}
	
}

 

728x90
반응형

'알고리즘 > 백준' 카테고리의 다른 글

[BAEKJOON] 3036 링  (2) 2022.09.23
[BAEKJOON] 2981 검문  (0) 2022.09.22
[BAEKJOON] 24060 알고리즘 수업 - 병합 정렬 1  (1) 2022.09.19
[BAEJOON] 2743 단어 길이 재기  (0) 2022.09.19
[BAEKJOON] 25501 재귀의 귀재  (2) 2022.09.10
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
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
글 보관함