C++编程 输入两个正整数m和n,求其最大公约数和最小公倍数

请大神帮忙看看,最小公倍数那里出问题了。。。#include<iostream>usingnamespacestd;intmain(){intm,n,Max;inttem... 请大神帮忙看看,最小公倍数那里出问题了。。。

#include<iostream>
using namespace std;

int main()
{
int m,n,Max;
int temp1,temp2;

cout<<"please input two numbers:"<<endl;
cin>>m>>n;

Max=(m>n)?m:n;
for(int i=1;i<Max;i++)
{
if(m%i==0&&n%i==0)
{
temp1=i;
}
}
cout<<"最大公约数为:"<<temp1<<endl;

//最小公倍数这里出问题了。。。
temp2=m*n;
for(int j=1;j<temp2;j++)
{
if(temp2%j==0&&temp2%m==0&&temp2%n==0)
{
temp2=temp2/j;
}else
{
temp2=temp2*(j-1);
}
}
cout<<"最小公倍数为:"<<temp2<<endl;

return 0;
}
展开
 我来答
flishandy123
2014-08-11 · 超过18用户采纳过TA的回答
知道答主
回答量:75
采纳率:0%
帮助的人:37.8万
展开全部

求出公约数以后temp1以后,公倍数的公式为m*n/temp1,看下面代码

#include<iostream>
using namespace std;
 
int main()
{
    int m = 0,n = 0,min = 0;
    int temp1 = 1,temp2 = 1;
 
    cout<<"please input two numbers:"<<endl;
    cin>>m>>n;
 
    min=(m < n) ? m : n;
    for(int i=1;i<min;i++)
    {
        if(m%i==0&&n%i==0)
        {
            temp1=i;
        }
    }
    cout<<"公约数:"<<temp1<<endl;
 
    //公倍数问题
    temp2 = m * n / temp1;
    cout<<"公倍数:"<<temp2<<endl;
    return 0;
}
菱漓仙洵
2014-08-11 · TA获得超过210个赞
知道小有建树答主
回答量:361
采纳率:50%
帮助的人:255万
展开全部
这样呢 ?
temp2=m*n;
for(int j=1;j<=temp2;j++)
{
if(m*j == n*j)
{
temp2 = m*j;

break;

}
}
追问
我想知道为什么我的程序里,关于最小公倍数的部分是错的?能解释一下吗?
追答
先说楼下的办法真心好。
然后就是你的怎么错了?我觉的break很重要。你第一次找到结果后就是最小公倍数了,要跳出啊
仔细读了一下,发现你的求法根本就是不对滴吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
匿名用户
2014-08-11
展开全部
我不懂你的最小公倍数算法是怎么想出来的,但我可以推荐你一个办法,m*n/temp1这个就是最小公倍数了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式