c语言中如何求两个数的最大公约数和最小公倍数?

 我来答
20081121126
2010-12-08 · TA获得超过253个赞
知道答主
回答量:55
采纳率:0%
帮助的人:64.1万
展开全部
直接编写两个函数就行了!!
#include<stdio.h>
int yueshu(int m,int n)
{
int t;
if(m>n)
t=m,m=n,n=t; //替换,保证m为较大的数
while(n!=0)
{
t=m%n;
m=n;
n=t;
}
return m;
}
int beishu(int m,int n)
{
return m*n/yueshu(m,n); //最小公倍数即为两个数的乘积除以最大公约数
}
main()
{
int m,n,s,t;
while(scanf("%d%d",&m,&n))
{
s=yueshu(m,n);
printf("%d\n",s);
t=beishu(m,n);
printf("%d\n",t);
}
}
淮漪
2010-12-08
知道答主
回答量:76
采纳率:0%
帮助的人:20.3万
展开全部
main()
{long m,n,i=1,j,s;
scanf("%ld,%ld",&m,&n);
for(;i<=m&&i<=n;i++)
{if(m%i==0&&n%i==0) s=i;}
if(m>=n) j=m;
else j=n;
for(;!(j%m==0&&j%n==0);j++);
printf("s=%ld,j=%ld\n",s,j);
},我有C语言答案。。要的找我。。。
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
banxi1988
2010-12-08 · TA获得超过579个赞
知道小有建树答主
回答量:327
采纳率:66%
帮助的人:271万
展开全部
/***
*@author:banxi1988
*@date:2010-12-018
*/

#include<stdio.h>

/* 求自然数m和n的最大公约数 欧几里得算法.
*/
int
gcd (int u, int v)
{
do
{
int t = u % v;
u = v;
v = t;
}
while (v);

return u;
}

/* 求自然数m和n的最大公约数 连续整数检测法. */
int
cgcd (int u, int v)
{
int t = u>v?v:u;
do{
if((u%t==0)&&(v%t==0))return t;
else t--;
}while(t>0);

}
int main(void){
int m,n;
printf("请输入两个正整数:\n");
scanf("%d%d",&m,&n);

printf("%d,%d的用连续整数检测法算得最大公约数是 :%d",m,n,cgcd(m,n));
printf("%d,%d 的用欧几里得算法算得最大公约数是:%d",m,n,gcd(m,n));

return 0;
}
/***运行结果如下:

请输入两个正整数:
3 5
3,5的用连续整数检测法算得最大公约数是:1
3,5的用欧几里得算法算得最大公约数是:1
---------------------------------------------
请输入两个正整数:
8 48
8,48的用连续整数检测法算得最大公约数是:8
8,48的用欧几里得算法算得最大公约数是

**/
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ondip78
2010-12-10 · TA获得超过8999个赞
知道小有建树答主
回答量:1798
采纳率:0%
帮助的人:910万
展开全部
#include<stdio.h>

void main()
{
int a,b,t;
int r,x;
printf("Input two numbers!\n");
scanf("%d,%d",&a,&b);
x = a * b;
if (a < b)
{
t = a;
a = b;
b = t;
}
while (b != 0)
{
r = a % b;
a = b;
b = r;
}
printf("最大公约数为:%d\n",a);
printf("最小公倍数为:%d\n",x/a);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
sun_siliang
2010-12-08 · TA获得超过2.6万个赞
知道大有可为答主
回答量:9913
采纳率:100%
帮助的人:4632万
展开全部
#include<stdio.h>
void main()
{int a,b,num1,num2,temp;
scanf("%d%d",&num1,&num2);
if(num1<num2){temp=num1;num1=num2;num2=temp;}
a=num1;b=num2;
while(b!=0)
{temp=a%b;
a=b;
b=temp;}
printf("%d\n",a);
printf("%d\n",num1*num2/a);
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式