운동하는 개발자/알고리즘, 코딩테스트
Beakjoon] 최소공배수 (백준 1934코테) - 정수론 (C++)
우용현
2023. 12. 28. 22:20
728x90
🅰️문제주소 : https://www.acmicpc.net/problem/1934
🚩문제
🪡풀이
- 우선 유클리드 호제법으로 최대공약수를 구해야한다
- 최소공배수 = 'A*B / 최대공약수' 공식에 대입한다 끝
☕코드는 아래 숨김
더보기
#include <iostream>
int main()
{
std::ios::sync_with_stdio(false);
std::cout.tie(0);
std::cin.tie(0);
int T, A, B;
std::cin >> T;
for (int i = 0; i < T; ++i) {
std::cin >> A >> B;
int big, small;
if (A <= B) { //A가 B보다 작다는 표현이 명확하지 않아서 조건넣음
big = B;
small = A;
}
else {
big = A;
small = B;
}
while (small != 0) { //재귀 함수로 더 깔끔하게 구현가능
int temp_mod = big % small;
big = small;
small = temp_mod;
}
std::cout << A * B / big << "\n";
}
return 0;
}
💡알게 된 것
- 유클리드 호제법
1) A와 B의 최대공약수를 구하려면 큰수/작은수의 나머지값을 구한다
2) '기존 작은수'가 '다음번 큰수'가 되고 '구했던 나머지 값'이 '다음번 작은수'가 된다.
3) 나머지가 0이될때까지 반복해서 나머지가 0일때 '작은수' 값이 최대 공약수이다
- 최소 공배수는 'A*B/최대 공약수'
728x90