여기서 우리는 두 개 이상의 숫자의 gcd를 얻는 방법을 볼 것입니다. 두 숫자의 gcd를 찾는 것은 쉽습니다. 두 개 이상의 숫자의 gcd를 찾으려면 gcd의 결합 규칙을 따라야 합니다. 예를 들어, {w, x, y, z}의 gcd를 찾으려면 {gcd(w,x), y, z}, 그러면 {gcd(gcd(w,x), y) , z}, 그리고 마지막으로 {gcd(gcd(gcd(w,x), y), z)}. 배열을 사용하면 매우 쉽게 수행할 수 있습니다.
알고리즘
gcd(a,b)
begin if a is 0, then return b end if return gcd(b mod a, a) end
getArrayGcd(arr, n)
begin res := arr[0] for i in range 1 to n-1, do res := gcd(arr[i], res) done return res; end
예시
#include<iostream>
using namespace std;
int gcd(int a, int b) {
if (a == 0)
return b;
return gcd(b%a, a);
}
int getArrayGcd(int arr[], int n) {
int res = arr[0];
for(int i = 1; i < n; i++) {
res = gcd(arr[i], res);
}
return res;
}
main() {
int arr[] = {4, 8, 16, 24};
int n = sizeof(arr)/sizeof(arr[0]);
cout << "GCD of array elements: " << getArrayGcd(arr, n);
} 출력
GCD of array elements: 4