ブルート フォース メソッドは、考えられるすべての約数を調べて、最大公約数として最大の約数を見つけるという、単純かつ直接的な方法です。
#include <stdio.h> int gcd(int a, int b) { int i, result = 1; for(i = 1; i <= a && i <= b; i++) { if(a % i == 0 && b % i == 0) { result = i; } } return result; } int main() { int a, b; printf("请输入两个整数: "); scanf("%d%d", &a, &b); printf("最大公约数为:%d ", gcd(a, b)); return 0; }
ユークリッド除算法 (ユークリッド アルゴリズムとも呼ばれる) は、2 つの整数の最大公約数が小さい方の数に等しいという単純な数学的原理に基づいています。数値: 差異の最大公約数。
#include <stdio.h> int gcd(int a, int b) { int remainder; while(b != 0) { remainder = a % b; a = b; b = remainder; } return a; } int main() { int a, b; printf("请输入两个整数: "); scanf("%d%d", &a, &b); printf("最大公约数为:%d ", gcd(a, b)); return 0; }
多相減算法も、最大公約数を見つけるためによく使用される方法です。2 つの数値を継続的に減算して差を取得し、その後、 2 つの数値が等しくなるまでの最大公約数。
#include <stdio.h> int gcd(int a, int b) { while(a != b) { if(a > b) { a = a - b; } else { b = b - a; } } return a; } int main() { int a, b; printf("请输入两个整数: "); scanf("%d%d", &a, &b); printf("最大公约数为:%d ", gcd(a, b)); return 0; }
以上がC言語で最大公約数を求める方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。