鱼C论坛

 找回密码
 立即注册
查看: 721|回复: 1

[已解决]C++ 求最大公约数

[复制链接]
发表于 2020-9-7 13:24:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
//请完成求最大公约数算法,补全函数里的代码段
#include <iostream>
#include <string.h>

int ComFactor(int m, int n)
{
        int r = m % n;
        if (r != 0){
        n--;
        return ComFactor(m,n)};           
        return n;
}

int main( )
{
        int m,n;
        cin>>m>>n; 
        cout << ComFactor(m, n) << endl;
          return 0;
}
学校作业
if 语句是自己写的,其他都是原题。
不知道哪里错了
最佳答案
2020-9-7 13:37:17
帮你修改了。不应该用if,应该用while循环
//请完成求最大公约数算法,补全函数里的代码段
#include <iostream>
#include <string.h>
using namespace std;

int ComFactor(int m, int n)
{
    int r = m % n;
    while (r != 0){
        m=n;
        n=r;
        r=m%n;
    }   
    return n;
};

int main( )
{
    int m,n;
    cin>>m>>n; 
    cout << ComFactor(m, n) << endl;
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-9-7 13:37:17 | 显示全部楼层    本楼为最佳答案   
帮你修改了。不应该用if,应该用while循环
//请完成求最大公约数算法,补全函数里的代码段
#include <iostream>
#include <string.h>
using namespace std;

int ComFactor(int m, int n)
{
    int r = m % n;
    while (r != 0){
        m=n;
        n=r;
        r=m%n;
    }   
    return n;
};

int main( )
{
    int m,n;
    cin>>m>>n; 
    cout << ComFactor(m, n) << endl;
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-13 06:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表