最大公约数和最小公倍数的方法
请教为什么我的这两种的结果吧一样?第一种:#include <stdio.h>
void main()
{
int max(int m,int n);
int min(int m,int n);
int x,y,m,n;
printf("Please enter m and n:");
scanf("%d,%d",&m,&n);
x=max(m,n);
y=min(m,n);
printf("最大公约数是:%d\n",x);
printf("最小公倍数是:%d\n",y);
}
int max(int m,int n)
{int t,r,max;
if(n>m) {t=m;m=n;n=t;}
r=m%n;
while(r!=0)
{m=n;
n=r;
r=m%n;
}
max=n;
return(max);
}
int min(int m,int n)
{int i,t;
if(n>m)
t=n;
else
t=m;
for(i=t;;i++)
if(i%m==0&&i%n==0)
break;
return i;
}
第二种
#include <stdio.h>
void main()
{
int max(int m,int n);
int min(int m,int n);
int x,y,m,n;
printf("Please enter m and n:");
scanf("%d,%d",&m,&n);
x=max(m,n);
y=min(m,n);
printf("最大公约数是:%d\n",x);
printf("最小公倍数是:%d\n",y);
}
int max(int m,int n)
{int t,r,max;
if(n>m) {t=m;m=n;n=t;}
r=m%n;
while(r!=0)
{m=n;
n=r;
r=m%n;
max=n;
}
return(max);
}
int min(int m,int n)
{int i,t;
if(n>m)
t=n;
else
t=m;
for(i=t;;i++)
if(i%m==0&&i%n==0)
break;
return i;
}
为什么第一种对呢 为什么max=n;放的位置不同结果就不一样呢!