鱼C论坛

 找回密码
 立即注册
查看: 1809|回复: 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 编辑

  1. #include <stdio.h>

  2. // 输入两个正整数m和n,求其最大公约数和最小公倍数
  3. int main(){
  4.     int m, n, i;
  5.     int num_1, num_2;                                                   // 改了这里
  6.    
  7.     printf("请分别输入两个数:");
  8.     scanf("%d%d", &m, &n);
  9.    
  10.     num_1 = m;                                                                // 加了这行
  11.     num_2 = n;                                                                 // 加了这行
  12.    
  13.     if (m >= n){
  14.         while (n != 0){
  15.             i = m % n;
  16.             m = n;
  17.             n = i;
  18.         }
  19.         printf("最大公约数为%d\n", m);                                               // 改了这里
  20.         printf("最小公倍数为%d\n", num_1 * num_2 / m);                                             // 改了这里
  21.     } else {
  22.         while (m != 0){
  23.             i = n % m;
  24.             n = m;
  25.             m = i;
  26.         }
  27.         printf("最大公约数为%d\n", n);
  28.         printf("最小公倍数为%d\n", num_1 * num_2 / n);                                // 加了 \n
  29.     }
  30.    
  31.     return 0;
  32. }
复制代码

屏幕截图 2023-03-22 150522.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

  1. #include <stdio.h>

  2. // 输入两个正整数m和n,求其最大公约数和最小公倍数
  3. int main(){
  4.     int m, n, i;
  5.     int num_1, num_2;                                                   // 改了这里
  6.    
  7.     printf("请分别输入两个数:");
  8.     scanf("%d%d", &m, &n);
  9.    
  10.     num_1 = m;                                                                // 加了这行
  11.     num_2 = n;                                                                 // 加了这行
  12.    
  13.     if (m >= n){
  14.         while (n != 0){
  15.             i = m % n;
  16.             m = n;
  17.             n = i;
  18.         }
  19.         printf("最大公约数为%d\n", m);                                               // 改了这里
  20.         printf("最小公倍数为%d\n", num_1 * num_2 / m);                                             // 改了这里
  21.     } else {
  22.         while (m != 0){
  23.             i = n % m;
  24.             n = m;
  25.             m = i;
  26.         }
  27.         printf("最大公约数为%d\n", n);
  28.         printf("最小公倍数为%d\n", num_1 * num_2 / n);                                // 加了 \n
  29.     }
  30.    
  31.     return 0;
  32. }
复制代码

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-22 17:58

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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