C 語言實例 – 求兩數(shù)的最大公約數(shù)

C 語言實例 - 求兩數(shù)的最大公約數(shù)

C 語言實例 C 語言實例

用戶輸入兩個數(shù),求這兩個數(shù)的最大公約數(shù)。

實例 - 使用 for 和 if

#include <stdio.h> int main() { int n1, n2, i, gcd; printf("輸入兩個正整數(shù),以空格分隔: "); scanf("%d %d", &n1, &n2); for(i=1; i <= n1 && i <= n2; ++i) { // 判斷 i 是否為最大公約數(shù) if(n1%i==0 && n2%i==0) gcd = i; } printf("%d 和 %d 的最大公約數(shù)是 %d", n1, n2, gcd); return 0; }

運行結(jié)果:

輸入兩個正整數(shù),以空格分隔: 81 153
81 和 153 的最大公約數(shù)是 9

實例 - 使用 while 和 if

#include <stdio.h> int main() { int n1, n2; printf("輸入兩個數(shù),以空格分隔: "); scanf("%d %d",&n1,&n2); while(n1!=n2) { if(n1 > n2) n1 -= n2; else n2 -= n1; } printf("GCD = %d",n1); return 0; }

運行結(jié)果:

輸入兩個數(shù),以空格分隔: 81 153
GCD = 9

實例 - 適用正數(shù)和負數(shù)

#include <stdio.h> int main() { int n1, n2; printf("輸入兩個數(shù),以空格分隔: "); scanf("%d %d",&n1,&n2); // 如果輸入的是負數(shù),將其轉(zhuǎn)換為正數(shù) n1 = ( n1 > 0) ? n1 : -n1; n2 = ( n2 > 0) ? n2 : -n2; while(n1!=n2) { if(n1 > n2) n1 -= n2; else n2 -= n1; } printf("GCD = %d",n1); return 0; }

運行結(jié)果:

輸入兩個數(shù),以空格分隔: 81 -153
GCD = 9

實例 - 使用遞歸

#include <stdio.h> int hcf(int n1, int n2); int main() { int n1, n2; printf("輸入兩個正整數(shù): "); scanf("%d %d", &n1, &n2); printf("%d 和 %d 的最大公約數(shù)為 %d", n1, n2, hcf(n1,n2)); return 0; } int hcf(int n1, int n2) { if (n2 != 0) return hcf(n2, n1%n2); else return n1; }

C 語言實例 C 語言實例

相關(guān)文章
亚洲国产精品第一区二区,久久免费视频77,99V久久综合狠狠综合久久,国产免费久久九九免费视频