程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> C語言 >> 關於C語言 >> C語言中最大公約數求法

C語言中最大公約數求法

編輯:關於C語言

從鍵盤輸入兩個整數,輸出器最大公約數及最小公約數。

法一:窮舉法
#include<stdio.h>
main()
{
   int m,n,i;
   scanf("%d%d",&m,&n);
   for(i=m;;i--)
       if(m%i==0&&n%i==0) break;
   printf("%d,%d ",i,m*n/i);
}
---------------------------------------
#include<stdio.h>
main()
{
   int m,n,t,i;
   scanf("%d%d",&m,&n);
   for(i=1;i<=(m<n?m:n);i++)
      if(!(m%i)&&!(n%i)) t=i;
   printf("%d,%d ",t,m*n/t);
}
法二:輾轉相除法
#include<stdio.h>
main()
{
int m,n,t,r;
scanf("%d%d",&m,&n);
r=m*n;
t=m%n;
while(t)
{m=n;n=t;t=m%n;}
printf("%d,%d ",n,r/n);
}
分析:
40%32=8;
32%8=0;
故最大公約數為8
最小公倍數40*32/8=160

 

 

法四:相減法

 


#include<stdio.h>


main()
{
int m,n,r;
scanf("%d%d",&m,&n);
r=m*n;
while(m!=n)
if(m>n) m=m-n;
else n=n-m;
printf("%d,%d ",m,r/m);
}
分析:
40-32=8;
32-8=24;
24-8=16;
16-8=8;
8=8=0;
由於本人條件有限,借別人電腦,故只作簡單分析,如有不懂,請自行查閱資料。
如有錯誤,請指出

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved