728x90
BOJ 2702 초6 수학
문제
두 정수 a와 b 최소공배수는 두 수의 공통된 배수 중 가장 작은 수이고,
최대공약수는 두 수의 공통된 약수중 가장 큰 수이다.
a와 b가 주어졌을 때, 최소공배수와 최대공약수를 구하는 프로그램을 작성하시오.
시간 제한 : 1 초
메모리 제한 : 128 MB
입력
첫째 줄에 테스트 케이스의 개수 T(1<=T<=1,000)가 주어진다.
각 테스트 케이스는 두 정수 a와 b로 이루어져 있고, 공백으로 구분되어 있다. (1 <= a,b <= 1,000)
출력
각 테스트 케이스에 대해 최소공배수와 최대공약수를 차례대로 출력한다.
예제 입력 1
3
5 10
7 23
42 56
예제 출력 1
10 5
161 1
168 14
풀이
import sys
def lcm(a, b) :
return int((a*b) / gcd(a, b))
def gcd(a, b) :
if a == 0 :
return b
else :
return gcd(b % a, a)
input = sys.stdin.readline
t = int(input())
for i in range(t) :
a, b = map(int, input().split())
print(lcm(a, b), gcd(a, b))
728x90
'Algorithm(Python) > 부르트포스' 카테고리의 다른 글
[Algorithm] 백준 BOJ 10819 차이를 최대로(python 파이썬) (0) | 2022.07.01 |
---|---|
[Algorithm] 백준 BOJ 1057 토너먼트(python 파이썬) (0) | 2022.06.30 |
[Algorithm] 백준 BOJ 1120 문자열(python 파이썬) (0) | 2022.06.28 |
[Algorithm] 백준 BOJ 1075 나누기(python 파이썬) (0) | 2022.06.27 |
[Algorithm] 백준 BOJ 2501 약수구하기(python 파이썬) (0) | 2022.06.26 |