[Algorithm] 유클리드 호제법 (최대공약수, 최소공배수)

2024. 2. 5. 15:54· → 알고리즘 관련
목차
  1. 유클리드 호제법이란?
  2. Swift로 구현하기
  3. 최대공약수와 최소공배수의 관계
  4. 유클리드 호제법 증명

유클리드 호제법이란?

드디어 알고리즘을 공부하다가 처음 마주한 녀석이다. 두 양의 정수 최대공약수를 구하는 방법으로 유클리드 알고리즘이 있다. 아래의 설명이 가장 이해하기 쉬운것 같아서 가져왔다.

출처 : 나무위키

 

Swift로 구현하기

최대공약수를 영어로 하면 Greatest Common Divisor 이기 때문에 보통 GCD 라 한다. 결과값이 나올때까지 자기자신을 계속 사용하는 재귀함수를 구현하여 구할 수 있다. a > b 일 경우 a = bq + r 이기 때문에 r 을 a % b 로 구할 수 있어 반복이 가능하다. 만약 여기서 a < b 일 경우에도 b 가 0 이 되지 않기 때문에 결국 a < b 일 경우 gcd(a, b) = gcd(b, a) 로 결국 가기 때문에 고려할 필요가 없다.

func gcd(_ a: Int, _ b: Int) -> Int {
    if b == 0 {
        return a
    } else {
        return gcd(b, a % b)
    }
}


// 더 짧은 버전
func gcd(_ a: Int, _ b: Int) -> Int {
    return b == 0 ? a : gcd(b, a % b)
}

 

최대공약수와 최소공배수의 관계

직접 손으로 쓴... 아래와 같다... 결국 최대공약수 x 최소공배수는 두 수를 곱한것과 같다!

따라서 최대공배수 LCD (Largest Common Multiple) 는 아래와 같이 구할 수 있다.

func lcd(_ a: Int, _ b: Int) -> Int {
    return a * b / gcd(a, b)
}

 

유클리드 호제법 증명

아래는 증명법인데... 확실히 오랜만에 수학을 해서 그런지 어색하다.

 

'→ 알고리즘 관련' 카테고리의 다른 글

[Algorithm] 힙(Heap) 구현하기 (Swift)  (0) 2024.03.21
[Algorithm] 동적 프로그래밍 (DP, Dynamic Programming)  (0) 2024.03.20
[Algorithm] 순열과 조합 구하기 (Swift)  (0) 2024.03.09
[Algorithm] 팩토리얼 구하기 (Swift, 재귀 함수)  (0) 2024.03.09
[Swift] 진수 변환 (Radix)  (1) 2024.02.07
  1. 유클리드 호제법이란?
  2. Swift로 구현하기
  3. 최대공약수와 최소공배수의 관계
  4. 유클리드 호제법 증명
'→ 알고리즘 관련' 카테고리의 다른 글
  • [Algorithm] 동적 프로그래밍 (DP, Dynamic Programming)
  • [Algorithm] 순열과 조합 구하기 (Swift)
  • [Algorithm] 팩토리얼 구하기 (Swift, 재귀 함수)
  • [Swift] 진수 변환 (Radix)
Swift librarian
Swift librarian
Swift librarian
Swift Library
Swift librarian
전체
오늘
어제
  • 분류 전체보기 (231)
    • 📺 Programming (5)
    • → Architecture (2)
    • → Design Pattern (0)
    • → Computer Science (15)
    • ⚙️ Algorithm (0)
    • → 알고리즘 관련 (22)
    • → Problems (104)
    • 🚀 Project (0)
    • → 알쏭달쏭 (0)
    • → Shook (2)
    • → Solver (8)
    • → Taster (7)
    • → Outline (4)
    • → Pointer (2)
    • → Guesser (3)
    • 🦜 Swift (2)
    • → Swift Archive (12)
    • → Swift Study (12)
    • → Xcode (6)
    • 🧰 Framework (0)
    • → Foundation (1)
    • → UIKit (2)
    • → SwiftUI (3)
    • → CoreData (2)
    • → MapKit (1)
    • → CoreHaptic (1)
    • → User Notification (1)
    • → StoreKit (2)
    • 🏛️ Library (0)
    • → TCA (0)
    • 🐈‍⬛ Git (8)
    • → Git의 원리 (2)
    • → Git 심화 (1)
    • 📦 Other (1)
    • 👦🏻 Log (0)

최근 글

hELLO · Designed By 정상우.v4.2.2
Swift librarian
[Algorithm] 유클리드 호제법 (최대공약수, 최소공배수)
상단으로

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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