ShovelingLife
A Game Programmer
ShovelingLife
전체 방문자
오늘
어제
  • 분류 전체보기 (1066) N
    • 그래픽스 (57)
      • 공통 (19)
      • 수학 물리 (22)
      • OpenGL & Vulkan (1)
      • DirectX (14)
    • 게임엔진 (179) N
      • Unreal (69)
      • Unity (99) N
      • Cocos2D-X (3)
      • 개인 플젝 (8)
    • 코딩테스트 (221)
      • 공통 (7)
      • 프로그래머스 (22)
      • 백준 (162)
      • LeetCode (19)
      • HackerRank (2)
      • 코딩테스트 알고리즘 (8)
    • CS (235)
      • 공통 (21)
      • 네트워크 (44)
      • OS & 하드웨어 (55)
      • 자료구조 & 알고리즘 (98)
      • 디자인패턴 (6)
      • UML (4)
      • 데이터베이스 (7)
    • 프로그래밍 언어 (346)
      • C++ (167)
      • C# (88)
      • Java (9)
      • Python (33)
      • SQL (30)
      • JavaScript (8)
      • React (7)
    • 그 외 (9)
      • Math (5)
      • 일상 (5)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

  • Source Code 좌측 상단에 복사 버튼 추가 완료
  • 언리얼 엔진 C++ 빌드시간 단축 꿀팁
  • 게임 업계 코딩테스트 관련
  • 1인칭 시점으로 써내려가는 글들

인기 글

태그

  • 유니티
  • 티스토리챌린지
  • SQL
  • 프로그래머스
  • Unity
  • 백준
  • 배열
  • 포인터
  • C++
  • 그래픽스
  • 알고리즘
  • 함수
  • c#
  • 파이썬
  • 클래스
  • C
  • 언리얼
  • 문자열
  • 오블완
  • string

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
ShovelingLife

A Game Programmer

CS/자료구조 & 알고리즘

유클리드 호제법 - 최대공약수(GCD) 구하기

2023. 9. 4. 11:19

유클리드 알고리즘(Euclidean algorithm)은 2개의 자연수의 최대공약수를 구하는 알고리즘이다. 비교대상의 두 개의 자연수 a와 b에서(단 a>b) a를 b로 나눈 나머지를 r이라고 했을때 GCD(a, b) = GCD(b, r)과 같고 "r이 0이면 그때 b가 최대공약수이다."라는 원리를  활용한 알고리즘이다.

ex) GCD(24,16) -> GCD(16,8) -> GCD(8,0) : 최대공약수 = 8

구현

재귀 함수 활용

int GCD(int a, int b)
{
    if(b==0)return a;
    else return GCD(b,a%b);
}

 

반복문 활용

int GCD(int a,int b){
    while(1){
        int r = a%b;
        if(r==0) return b;
		
        a = b;
        b = r;
    }
}

 

다항식일 경우

int a = 8;
int b = 16;
int c = 24;
	
int result = GCD(a,b); //a와 b의 최대공약수 -> result
result = GCD(result,c); //a와 b의 최대공약수 result와 c의 최대공약수

printf("%d",result);

다항식일 경우 GCD를 구하는 함수를 먼저 구현한 뒤 위와 같이 a와 b의 최대공약수를 먼저 계산한 후 계산된 최대공약수와 c의 최대공약수를 구하는 순차적인 방식으로 최대공약수를 구할 수 있다. 

 

장점

유클리드 호제법의 장점은 빠르다는 것이다. 일반적으로 최대공약수를 구하는 가장 쉬운 방법은 2부터 min(A, B)까지 모든 정수로 나누어 보는 방법이 있을 것 같은데 이의 경우 모든 정수를 나눠야 하므로 시간 복잡도는 O(N)이 된다. 하지만 유클리드 호제법을 사용한다면 비교대상의 두 수 a와 b에서 a를 b로 나눈 나머지를 r이라고 했을 때 a % r이 0이 될 때까지 반복을 해주는 방식으로 최대공약수를 산출하기에 시간 복잡도를 O(Log N)으로 줄일 수 있어 좀 더 효율적인 알고리즘을 작성할 수 있다.

 

단점

유클리드 호제법의 단점이라고 하면 최대공약수는 빠르게 산출이 가능하지만 최소공배수를 계산함에 있어서는 비교 대상의 초기값 a와 b를 특정 변수에 저장을 시키고 있어야 한다는 점이다. 예를 들어 GCD(24,16) -> GCD(16,8) -> GCD(8,0)로 유클리드 알고리즘이 진행된다면 기존의 값 a와 b는 계속해서 그 숫자가 변할 것이다. 이렇게 된다면 GCD * (GCD/a) * (GCD/b)인 최소공배수를 구할 수 없다. 

 

최소공배수 구하기

int LCM(int a, int b)
{
    return a * b / GCD(a,b);
}

GCD를 구하는 알고리즘을 먼저 유클리드 호제법을 활용하여 구현한 후 a * b / GCD(a, b)를 해주면 최소공배수를 구할 수 있다.

 

[Algorithm] 유클리드 호제법 - 최대공약수(GCD) 구하기 (tistory.com)

저작자표시 (새창열림)

'CS > 자료구조 & 알고리즘' 카테고리의 다른 글

[C++] 배열 초기화, 벡터 초기화, fill 함수  (0) 2023.09.16
각 정렬의 특징 및 장단점 & 시간복잡도 + 코드  (0) 2023.09.07
에라토스테네스의 체  (0) 2023.09.03
C++ 다익스트라(Dijkstra) 알고리즘 개념 및 구현 (무방향 그래프)  (0) 2023.08.30
[C#] 연결 리스트(Linked List)란?  (0) 2023.08.29
    'CS/자료구조 & 알고리즘' 카테고리의 다른 글
    • [C++] 배열 초기화, 벡터 초기화, fill 함수
    • 각 정렬의 특징 및 장단점 & 시간복잡도 + 코드
    • 에라토스테네스의 체
    • C++ 다익스트라(Dijkstra) 알고리즘 개념 및 구현 (무방향 그래프)
    ShovelingLife
    ShovelingLife
    Main skill stack => Unity C# / Unreal C++ Studying Front / BackEnd, Java Python

    티스토리툴바