清辞136 2022-10-28 11:44 采纳率: 50%
浏览 276
已结题

输入长度为 n 的一个正整数序列,要求输出序列中最长连续自然数序列的长度。输入 第一行,一个整数n,第二行,n 个整数 。输出 一个数,最长连续自然数的个数。

#include<stdio.h>
int main(void)
{
/Begin/
int n,x0 = 0,x1,i = 0,max = 0;
scanf("%d",&n);

 do
  {
      scanf("%d",&x1);
      n--;
      if(x1 == x0 + 1)
      i++;
      else
      
      {
        if(i > max)
        {
            max = i;
            i = 1;
        }
      }
      x0 = x1;      
  }while(n != 0);
  
  printf("%d",max) 
  /*********End**********/ 
  return 0;

}

  • 写回答

2条回答 默认 最新

  • 快乐鹦鹉 2022-10-28 12:06
    关注

    假设输入的是1 2 3的话,你的max是不会被赋值的啊。当循环结束后,你需要再判断i值是否大于max
    另外,如果输入 1 1 1的话,你的max会是2,这也是不对的。所以不能使用x0的默认值,应该对第一个输入的数进行判断处理

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

报告相同问题?

问题事件

  • 系统已结题 11月8日
  • 已采纳回答 10月31日
  • 创建了问题 10月28日

悬赏问题

  • ¥15 CST仿真别人的模型结果仿真结果S参数完全不对
  • ¥15 误删注册表文件致win10无法开启
  • ¥15 请问在阿里云服务器中怎么利用数据库制作网站
  • ¥60 ESP32怎么烧录自启动程序
  • ¥50 html2canvas超出滚动条不显示
  • ¥15 java业务性能问题求解(sql,业务设计相关)
  • ¥15 52810 尾椎c三个a 写蓝牙地址
  • ¥15 elmos524.33 eeprom的读写问题
  • ¥15 用ADS设计一款的射频功率放大器
  • ¥15 怎么求交点连线的理论解?