從鍵盤輸入兩個整數,輸出器最大公約數及最小公約數。
法一:窮舉法
#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;
由於本人條件有限,借別人電腦,故只作簡單分析,如有不懂,請自行查閱資料。
如有錯誤,請指出