• TOC {:toc}

이 글은 백준 온라인 저지의 2609번 문제를 파이썬(Python)으로 풀이한 것을 모아놓은 글입니다.

일종의 연습 기록이며 제가 정답을 받은 코드와 참고할만한 다른 코드를 같이 기록합니다. 필요한 경우 코드에 대한 해설을 기록합니다만 코드는 통과했어도 해설은 틀릴 수 있기 때문에 가볍게 참고해주시길 부탁드립니다. 피드백은 편하신 방법으로 자유롭게 주시면 감사하겠습니다.

2021.04.13

메모리 시간 코드 길이
28776 KB 92 ms 220 B
def get_gcb(a, b):
    if a < b:
        get_gcb(b, a)
    if a % b == 0:
        return b
    else:
        return get_gcb(b, a % b)


a, b = map(int, input().split())
gcb = get_gcb(a, b)

print(gcb)
print(a * b // gcb)

아이디어 & 풀이

[[boj-1934]]{1934번} 문제의 참고 답안을 참고하면 된다.

참고 답안 1

a, b = map(int, input().split())

q, r = a, b
# 혹은 그냥 while r: 로 써도 된다 (r이 0이 될 때 까지 실행).
while r != 0:
    q, r = r, q % r

print(q)
print(a * b // q)

아이디어 & 풀이

유클리드 호제법을 while을 이용해서 더 간단하게 구현한다.

# for a > b
while b:
    a, b = b, a % b

참고 답안 2

import math

a, b = map(int, input().split())
print(math.gcd(a, b))
print(math.lcm(a, b))

아이디어 & 풀이

math 라이브러리의 최소공배수, 최대공약수 메소드를 사용한다.