GCD(Great Common Divisior), LCM(Least Common Multiple)

2023. 3. 24. 16:43·코딩테스트/Python
728x90
반응형

1. for문 활용

a, b = 12, 10

# GCD - 최대공약수
for i in range(min(a,b), 0, -1):
    if a % i == 0 and b % i == 0:
        gcd = i
        break

# LCM - 최소공배수
for i in range(a*b, 0, -1):
    if i % a == 0 and i % b == 0:
        lcm = i
        break

2. 유클리드 호제법 활용

a를 b로 나눈 나머지를 r이라 하면(단, a>b), a와 b의 최대공약수는 b와 r의 최대공약수와 같다

 

위 정의에 따라, r가 0일때의가 최대공약수가 된다. 또한, 두 수의 곱을 최대공약수로 나눈 값이 최소공배수가 된다. 

# GCD - 최대공약수
def GCD(a, b):
    while b > 0:
        a, b = a // b, a % b
    return a
    
# LCM - 최소공배수
def LCM(a, b):
    return (a*b) // GCD(a, b)

3. Math 라이브리러리 활용

import math

a,b = 12, 10
gcd = math.gcd(a, b)
lcm = math.lcm(a, b)
저작자표시 (새창열림)

'코딩테스트 > Python' 카테고리의 다른 글

구간 합 (Prefix Sum)  (0) 2023.07.04
[Data Structure] 트리  (0) 2023.03.30
[Baekjoon] 1992. 쿼드트리  (0) 2023.01.30
[Baekjoon] 1389. 케빈 베이컨의 6단계 법칙  (0) 2023.01.30
[Programmers] Level 3. 경주로 건설  (0) 2023.01.20
'코딩테스트/Python' 카테고리의 다른 글
  • 구간 합 (Prefix Sum)
  • [Data Structure] 트리
  • [Baekjoon] 1992. 쿼드트리
  • [Baekjoon] 1389. 케빈 베이컨의 6단계 법칙
swwho
swwho
일상을 데이터화하다
  • swwho
    하루한장
    swwho
  • 전체
    오늘
    어제
    • 분류 전체보기 (188)
      • ML_DL (39)
        • MUJAKJUNG (무작정 시리즈) (18)
        • 딥러닝 공부하기 (21)
      • 데이터사이언스 (1)
        • EDA (1)
        • 데이터과학을 위한 통계 (0)
      • 데이터엔지니어링 (2)
      • 논문리뷰 (2)
        • Computer Vision (2)
      • Python 활용하기 (12)
      • 코딩테스트 (127)
        • Python (109)
        • MySQL (14)
      • Git (3)
      • MySQL 활용하기 (0)
      • 일상 이야기 (1)
  • 블로그 메뉴

    • 홈
    • 태그
  • 최근 글

  • 250x250
  • hELLO· Designed By정상우.v4.10.3
swwho
GCD(Great Common Divisior), LCM(Least Common Multiple)
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.