章鱼oM0 2022-07-25 10:34 采纳率: 100%
浏览 42
已结题

求最大公约数出错!!

求问,为什么这段代码不能求最大公约数
#include<stdio.h>

int main()
{int m,n,max,i,j;
printf("请输入两个整数n,m:");
scanf("%d,%d",&m,&n);
for(i=1;i<m;i++)
for(j=1;j<m;j++)
{if(m/i==n/i)
max=m/i;
printf("最大公约数为%d,max");
}
return 0;
}

  • 写回答

3条回答 默认 最新

  • a5156520 2022-07-25 11:07
    关注

    第二个for循环里面判断最大公约数那里错了,条件改为m对i求余与n对j求余相等(保证为i和j分别为m和n的约数),以及i==j即可(保证为公约数),然后ma赋值为i或j都可(即保存当前约数),等循环结束,max里面即存储了最大的公约数。
    修改如下:

    
    
    #include<stdio.h>
    
    int main()
    {
        int m,n,max,i,j;
        printf("请输入两个整数n,m:");
        scanf("%d,%d",&n,&m);
        
        for(i=1;i<m;i++){
            for(j=1;j<n;j++)
            {
                if(m%i==n%j&&(i==j)){
                    //printf("m=%d,n=%d,i=%d,j=%d\n",m,n,i,j);
                    max=i;
                }
                    
                
            }
        }
            
        printf("最大公约数为%d",max);    
        return 0;
    }
    

    img

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

报告相同问题?

问题事件

  • 系统已结题 10月27日
  • 已采纳回答 10月19日
  • 创建了问题 7月25日

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度