C++ 最长连号

文章目录


一、题目描述

最长连号

题目描述

输入长度为 n n n 的一个正整数序列,要求输出序列中最长连号的长度。

连号指在序列中,从小到大的连续自然数。

输入格式

第一行,一个整数 n n n。

第二行, n n n 个整数 a i a_i ai,之间用空格隔开。

输出格式

一个数,最长连号的个数。

样例 #1

样例输入 #1

复制代码
10
1 5 6 2 3 4 5 6 8 9

样例输出 #1

复制代码
5

提示

数据规模与约定

对于 100 % 100\% 100% 的数据,保证 1 ≤ n ≤ 1 0 4 1 \leq n \leq 10^4 1≤n≤104, 1 ≤ a i ≤ 1 0 9 1 \leq a_i \leq 10^9 1≤ai≤109。


二、参考代码

cpp 复制代码
#include <iostream>

using namespace std;
const int maxn = 10001;
int arr[maxn];


int main(void) {
    
    int n;
    cin >> n;
    for (int i = 0; i < n; i++)
    {
        cin >> arr[i];
    }
    int cnt = 1;
    int max = 0;
    for (int i = 0; i < n - 1; i++)
    {
        if (arr[i + 1] - arr[i] == 1)
        {
            cnt++;
        }
        else
        {
            cnt = 0;
        }

        if (cnt > max)
        {
            max = cnt;
        }
    }
    cout << ++max << endl;
}

相关推荐
疯狂打码的少年6 分钟前
有序线性表删除一个元素:顺序存储 vs 单链表,平均要移动多少个元素?
数据结构·算法·链表
y = xⁿ20 分钟前
20天速通LeetCode day07:前缀和
数据结构·算法·leetcode
t***54437 分钟前
Dev-C++中哪些选项可以设置
开发语言·c++
载数而行5201 小时前
算法集训1:模拟,枚举,错误分析,前缀和,差分
算法
hehelm1 小时前
vector模拟实现
前端·javascript·算法
2301_803554521 小时前
C++ 并发核心:std::promise、std::future、std::async 超详细全解
开发语言·c++
EverestVIP1 小时前
C++ 成员函数的指针
c++
俺不要写代码2 小时前
线程启动、结束,创建线程多法、join,detach,线程的移动语义
服务器·开发语言·网络·c++
思麟呀2 小时前
应用层协议HTTP
linux·服务器·网络·c++·网络协议·http
Tina学编程2 小时前
[HOT 100]今日一练------划分字母区间
算法·hot 100