如何用C语言求最小公倍数。。。

 我来答
zzd19941022
2016-10-05 · TA获得超过272个赞
知道答主
回答量:26
采纳率:0%
帮助的人:14.7万
展开全部
我代码复制给你看。

#include<stdio.h>
int GCD(int a,int b) //GCD表示最大公约数
{
int z= a<b?a:b; //我从输入的两个数中较小的那个开始判断是不是最大公约数,不是就一直-1
while(z>=1) // 直到找到能同时被X,Y整除的数,它就是最大公约数了。
{
if(a%z==0&&b%z==0) break;//最快满足这个条件的Z就是最大公约数
z--;
}
return z;
}
int LCM(int a,int b) //LCM表示最小公倍数
{
int z=a>b?a:b; //我从输入的两个数中最大的那个开始判断是不是最小公倍数,不是就一直+1
while(z<=(a*b)) //两个非零数a,b,我们知道a*b肯定是它的公倍数 ,所以从两个数的最大那个数开始
{ //一直到a*b肯定存在最小公倍数
if(z%a==0&&z%b==0)break; //最快满足这个条件的Z就是最小公倍数
z++;
}
return z;
}
int main()
{
while(1)
{
int x,y,z,d;
printf("请输入两个整数:");
scanf("%d %d",&x,&y);
z=GCD(x,y);
d=LCM(x,y);
printf("这两个数的最大公约数是%d\n",z);
printf("这两个数的最小公倍数是%d\n",d);
printf("\n");
}
}
帐号已注销
推荐于2019-10-16 · TA获得超过25.9万个赞
知道小有建树答主
回答量:2206
采纳率:96%
帮助的人:78.1万
展开全部

【利用C语言求最小公倍数主要用到if whie循环】

例子如下:

直接编译,程序输出结果中任意输入两个数,如5和8,然后按回车,结果如下图所示:

两个或多个整数公有的倍数叫做它们的公倍数,其中除0以外最小的一个公倍数就叫做这几个整数的最小公倍数。

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
风若远去何人留
2015-07-01 · 知道合伙人互联网行家
风若远去何人留
知道合伙人互联网行家
采纳数:20412 获赞数:450106
专业C/C++软件开发

向TA提问 私信TA
展开全部

先求两个 然后用结果和第三个求三个  依次类推,直到用前n-1个的最小公倍数和第n个数求最小公倍数就是结果了。


代码如下

int gcd(int m, int n)
{
if(m%n == 0) return n;
return gcd(n, m%n);
}

int lcm(int m, int n)
{
return m/gcd(m,n)*n;
}

int main()
{
int n, i, *a, r = 1;

scanf("%d",&n);
a = (int *) malloc(sizeof(int) * n);
for(i = 0;i < n; i ++)
scanf("%d",a+i);

for(i = 0; i < n; i ++)
r = lcm(r, a[i]);

printf("r = %d\n", r);

free(a);

return 0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
止雨乾惜玉
2020-01-20 · TA获得超过3753个赞
知道大有可为答主
回答量:3116
采纳率:26%
帮助的人:223万
展开全部
嗯,楼上的说的对,要把
break
语句放在
if
内执行。表示找到最小公倍数就退出。
你的错误在于:当条件不满足i%m==0&&i%n==0就执行了
break.比如说如果你输入2,3。循环第一次执行时i=1,显然条件就不满足,就得执行break
退出来了,所以你得不到想要的答案!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
zf930306
2012-03-22
知道答主
回答量:29
采纳率:0%
帮助的人:4.6万
展开全部
#include<stdio.h>
#include<math.h>
int main(void)
{
int a,b,c,d,x,y,repeat,ri,m,n;
printf("输入运算次数:\n");
scanf("%d",&repeat);
for(ri=1;ri<=repeat;ri++){
printf("输入两个不为0的数a和b:\n");
scanf("%d%d",&a,&b);
if(a==0||b==0)
printf("a或b为0,无法运算!\n");
else
{
if(a<b){
x=a;
a=b;
b=x;
}
m=a;
n=b;
y=a%b;
while(y!=0){
a=b;
b=y;
y=a%b;
}
c=b;
d=m*n/c;
printf("最大公约数是:%d\n最小公倍数是:%d\n",c,d);
}
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(10)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式