코딩테스트/프로그래머스
[프로그래머스] Level 2 - N개의 최소공배수 (Python)
ye0nn
2022. 6. 30. 23:58
https://programmers.co.kr/learn/courses/30/lessons/12953
코딩테스트 연습 - N개의 최소공배수
두 수의 최소공배수(Least Common Multiple)란 입력된 두 수의 배수 중 공통이 되는 가장 작은 숫자를 의미합니다. 예를 들어 2와 7의 최소공배수는 14가 됩니다. 정의를 확장해서, n개의 수의 최소공배
programmers.co.kr
✅ Solution
- 여러개의 수의 최소 공배수를 구하기 위해서는 두 수의 최소 공배수를 구한 뒤, 해당 수와 그 다음수와의 공배수 구하는 과정을 반복하면 된다.
- 예를 들어, [2, 6, 8, 14] 에서
- 2와 6의 최소공배수는 6이다.
- 그리고 6과 8의 최소 공배수는 24이다.
- 마지막으로 24와 14의 최소 공배수는 144다.
✅ Code
def get_gcd(x, y):
while y:
x, y = y, x % y
return x
def solution(arr):
lcm = arr[0]
for i in range(1, len(arr)):
gcd = get_gcd(lcm, arr[i])
lcm = lcm * arr[i] // gcd
return lcm