csdn_xjm 2023-03-09 15:09 采纳率: 87.5%
浏览 22
已结题

求最大公因数和最小公倍数,哪里错了

img

#include<stdio.h>

int main()
{
    int a,b,i,min,max;
    scanf("%lf %lf",&a,&b);
    min = (a<b)?a:b;
    for(i = min;i>= 1;i--)
    {
        if((a%i==0)&&(b%i==0))
        {
            printf("bigest num:%lf",i);
            break;
        }
    }
    printf("\n");
    max = (a>b)?a:b;
    for(i = max;;i++)
    {
        if((i%a==0)&&(i%b==0))
        {
            printf("min num:%lf",i);
            break;
        }
    }
    
    return 0;
}

  • 写回答

5条回答 默认 最新

  • dahe0825 2023-03-09 15:15
    关注

    参考GPT的回答和自己的思路,您的程序存在一些错误,可能是因为类型不匹配和printf语句格式错误导致的。

    1.输入应该使用%d格式,而不是%lf格式,因为您使用的是整数变量。
    2.在输出最大公约数和最小公倍数时,应该使用%d格式,而不是%lf格式,因为它们是整数。
    3.在printf语句中,应该使用\n来换行,而不是留空行。
    3.在找到最小公倍数后,应该退出循环,以避免不必要的计算。
    下面是一个修正后的程序:

    #include<stdio.h>
     
    int main()
    {
        int a, b, i, min, max, gcd, lcm;
        scanf("%d %d",&a,&b);
        min = (a<b)?a:b;
        for(i = min; i >= 1; i--)
        {
            if((a % i == 0) && (b % i == 0))
            {
                gcd = i;
                printf("GCD:%d\n", gcd);
                break;
            }
        }
        max = (a>b)?a:b;
        for(i = max; ; i++)
        {
            if((i % a == 0) && (i % b == 0))
            {
                lcm = i;
                printf("LCM:%d\n", lcm);
                break;
            }
        }
        return 0;
    }
    

    希望这能帮助您找到问题所在并解决它们。
    回答不易,还请采纳!!!

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 3月17日
  • 已采纳回答 3月9日
  • 创建了问题 3月9日

悬赏问题

  • ¥100 三相直流充电模块对数字电源芯片在物理上它必须具备哪些功能和性能?
  • ¥30 数字电源对DSP芯片的具体要求
  • ¥20 antv g6 折线边如何变为钝角
  • ¥30 如何在Matlab或Python中 设置饼图的高度
  • ¥15 nginx中的CORS策略应该如何配置
  • ¥30 信号与系统实验:采样定理分析
  • ¥100 我想找人帮我写Python 的股票分析代码,有意请加mathtao
  • ¥20 Vite 打包的 Vue3 组件库,图标无法显示
  • ¥15 php 同步电商平台多个店铺增量订单和订单状态
  • ¥17 pro*C预编译“闪回查询”报错SCN不能识别