반응형
최대공약수와 최소공배수
티어 : Silver 5
시간 제한 : 1 초
메모리 제한 : 128 MB
알고리즘 분류 :
문제
두 개의 자연수를 입력받아 최대 공약수와 최소 공배수를 출력하는 프로그램을 작성하시오.
입력
첫째 줄에는 두 개의 자연수가 주어진다. 이 둘은 10,000이하의 자연수이며 사이에 한 칸의 공백이 주어진다.
출력
첫째 줄에는 입력으로 주어진 두 수의 최대공약수를, 둘째 줄에는 입력으로 주어진 두 수의 최소 공배수를 출력한다.
예제 입출력

Algorithm
1. 유클리드 호제법 이용
1.1. 유클리드 호제법 함수 생성 - 재귀
1.2. A와 B의 최대 공약수는 B와 A%B의 최대공약수와 같다.
2. 최소공배수 = A*B%최대공약수
Code
import sys
input = sys.stdin.readline
def euclid(A, B):
R = A % B
# A가 B의 배수이면 Return
if R == 0:
return B
return euclid(B, R)
A, B = map(int, input().split())
answer = euclid(max(A, B), min(A, B))
print(answer)
print(A * B // answer)
메모리: 30864 KB
시간: 72 ms
반응형
'백준 > Python' 카테고리의 다른 글
[백준 11050] 이항 계수 1 Python (0) | 2022.03.05 |
---|---|
[백준 3036] 링 Python (0) | 2022.03.05 |
[백준 1018] 체스판 다시 칠하기 Python (0) | 2022.03.05 |
[백준 1012] 유기농 배추 Python (0) | 2022.03.05 |
[백준 1008] A/B Python (0) | 2022.03.05 |