Brynn0718 2021-02-26 12:46 采纳率: 75%
浏览 191
已采纳

蓝桥杯的既约分数中,自己的代码为什么输出不了?还有为什么有些人用辗转相除法求最大公倍数不用比较大小?

#include<stdio.h>
int main()
{
   int i,j,t,count=0;
   for(i=1;i<=2020;i++)
   for(j=1;j<=2020;j++)
   {
   while(i%j!=0)
   {
   	t=i%j;
   	i=j;
	j=t;
   }	
   if(j==1)
   count++;
   } 
   printf("%d",count); 
    return 0;
}
  • 写回答

1条回答 默认 最新

  • king_帅12 2021-02-26 13:51
    关注

    代码写的有问题吧,for循环内部j=1后重新循环导致死循环了,可以把

    while(i%j!=0)

     

    {

     

    t=i%j;

     

    i=j;

     

    j=t;

     

    } 这段代码放到一个方法里返回j

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 TLS1.2协议通信解密
  • ¥40 图书信息管理系统程序编写
  • ¥20 Qcustomplot缩小曲线形状问题
  • ¥15 企业资源规划ERP沙盘模拟
  • ¥15 树莓派控制机械臂传输命令报错,显示摄像头不存在
  • ¥15 前端echarts坐标轴问题
  • ¥15 ad5933的I2C
  • ¥15 请问RTX4060的笔记本电脑可以训练yolov5模型吗?
  • ¥15 数学建模求思路及代码
  • ¥50 silvaco GaN HEMT有栅极场板的击穿电压仿真问题