鱼C论坛

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

[已解决]有两个小问题,希望友友能帮忙看看

[复制链接]
发表于 2023-3-22 15:08:46 | 显示全部楼层 |阅读模式

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

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

x
#include <stdio.h>
           //输入两个正整数m和n,求其最大公约数和最小公倍数
int main(){
        int m,n,i;
        int num_1=m,num_2=n;
       
        printf("请分别输入两个数:");
        scanf("%d%d\n",&m,&n);
       
        if(m>=n){
                while(n!=0){
                        i=m%n;                       //有两个问题,一是为什么输入两个数后得用;才能进行下一步,而不是空格或者enter,二是为什么最小公倍数的结果为0;
                        m=n;
                        n=i;
                }
                printf("最大公约数为%d\n",n);
            printf("最小公倍数为%d",num_1*num_2/n);
        }else{
                while(m!=0){
                        i=n%m;
                        n=m;
                        m=i;
                }
                printf("最大公约数为%d\n",m);
            printf("最小公倍数为%d",num_1*num_2/m);
        }
       
        return 0;
}
最佳答案
2023-3-22 15:41:19
本帖最后由 isdkz 于 2023-3-22 15:45 编辑

#include <stdio.h>

// 输入两个正整数m和n,求其最大公约数和最小公倍数
int main(){
    int m, n, i;
    int num_1, num_2;                                                   // 改了这里
   
    printf("请分别输入两个数:");
    scanf("%d%d", &m, &n);
   
    num_1 = m;                                                                // 加了这行
    num_2 = n;                                                                 // 加了这行
   
    if (m >= n){
        while (n != 0){
            i = m % n;
            m = n;
            n = i;
        }
        printf("最大公约数为%d\n", m);                                               // 改了这里
        printf("最小公倍数为%d\n", num_1 * num_2 / m);                                             // 改了这里
    } else {
        while (m != 0){
            i = n % m;
            n = m;
            m = i;
        }
        printf("最大公约数为%d\n", n);
        printf("最小公倍数为%d\n", num_1 * num_2 / n);                                // 加了 \n
    }
   
    return 0;
}
屏幕截图 2023-03-22 150522.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-3-22 15:41:19 | 显示全部楼层    本楼为最佳答案   
本帖最后由 isdkz 于 2023-3-22 15:45 编辑

#include <stdio.h>

// 输入两个正整数m和n,求其最大公约数和最小公倍数
int main(){
    int m, n, i;
    int num_1, num_2;                                                   // 改了这里
   
    printf("请分别输入两个数:");
    scanf("%d%d", &m, &n);
   
    num_1 = m;                                                                // 加了这行
    num_2 = n;                                                                 // 加了这行
   
    if (m >= n){
        while (n != 0){
            i = m % n;
            m = n;
            n = i;
        }
        printf("最大公约数为%d\n", m);                                               // 改了这里
        printf("最小公倍数为%d\n", num_1 * num_2 / m);                                             // 改了这里
    } else {
        while (m != 0){
            i = n % m;
            n = m;
            m = i;
        }
        printf("最大公约数为%d\n", n);
        printf("最小公倍数为%d\n", num_1 * num_2 / n);                                // 加了 \n
    }
   
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-25 21:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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