最长连号

【题目描述】
  输入长度为 n 的一个正整数序列,要求输出序列中最长连号的长度。连号指在序列中,从小到大的连续自然数。
【输入格式】
  第一行,一个整数 n。
  第二行,n 个整数 a_i,之间用空格隔开。
【输出格式】
  一个数,最长连号的个数。
【输入输出样例】
【输入】
  10
  1 5 6 2 3 4 5 6 8 9
【输出】
   5
 
复制代码
#include<iostream>
using namespace std;
int a[100001]={};

int main(){
    /*
    10
    1 5 6 2 3 4 5 6 8 9
    */
    int n, ant=1, maxa=0; // ant=1。
    
     
    cin>>n;
    for(int i=0; i<n; i++){
        cin>>a[i];
    }
    for(int i=0; i<=n-2; i++){ // 相邻两个数字之间进行比较。 
        if(a[i+1]-a[i]==1){
            ant++;
        }else{
            ant=1;
        }
        if(maxa<ant) maxa=ant; // 计算最大值。 
    
    }
    cout<<maxa;
    return 0;
} 
复制代码

 

posted @   Hi,小董先生  阅读(319)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示