HJ180 游游的最长稳定子数组

  • 题目
  • 题解(30)
  • 讨论(15)
  • 排行

中等 通过率:51.28% 时间限制:1秒 空间限制:256M

知识点双指针

校招时部分企业笔试将禁止编程题跳出页面,为提前适应,练习时请使用在线自测,而非本地IDE。

描述

定义一个数组被称为稳定 ,当且仅当对于数组中任意相邻元素 ai,ai+1ai​,ai+1​,都有 ∣ai+1−ai∣≦1∣ai+1​−ai​∣≦1。

给定长度为 nn 的整数数组 aa,请你求出其最长稳定连续子数组的长度。

输入描述:

第一行输入一个整数 n(1≦n≦105)n(1≦n≦105)------数组长度。

第二行输入 nn 个整数 a1,a2,...,an(1≦ai≦109)a1​,a2​,...,an​(1≦ai​≦109)------数组元素。

输出描述:

输出一个整数,表示最长稳定连续子数组的长度。

示例1

输入:

复制代码
5
2 4 2 3 2

复制输出:

复制代码
3

复制说明:

复制代码
子数组 [2,3,2][2,3,2] 满足稳定条件且长度最大。
cpp 复制代码
#include <climits>
#include <iostream>
#include <bits/stdc++.h>
using namespace std;

int main() 
{
    int n;
    cin >> n;
    int left = -1;
    int indexLeft = 0, length = 0;
    for(int i = 0; i < n; ++i)
    {
        int elem;
        cin >> elem;
        if(abs(left - elem) <= 1)
        {
            length = max(length, i - indexLeft + 1);
        }
        else
        {
            indexLeft = i;
        }
        left = elem;
    }
    cout << length;
}
// 64 位输出请用 printf("%lld")
相关推荐
故事和你911 天前
洛谷-【图论2-1】树5
开发语言·数据结构·c++·算法·动态规划·图论
咖啡里的茶i1 天前
视觉显著目标的自适应分割与动态网格生成算法研究
人工智能·算法·目标跟踪
paeamecium1 天前
【PAT甲级真题】- String Subtraction (20)
数据结构·c++·算法·pat考试·pat
YL200404261 天前
047从前序与中序遍历序列构造二叉树
算法·leetcode
极梦网络无忧1 天前
password_hash
算法·哈希算法
计算机安禾1 天前
【c++面向对象编程】第25篇:仿函数(函数对象):重载operator()
开发语言·c++·算法
周末也要写八哥1 天前
在C++中使用预定义宏
开发语言·c++·算法
学会870上岸华师1 天前
C 语言程序设计——第一章课后编程题
c语言·开发语言·学习·算法
小小编程路1 天前
新手快速学 Python 极简速成指南
开发语言·c++·python
小马过河R1 天前
RAG检索优化策略:系统性四层框架解析
人工智能·python·算法·ai·llm·rag·问答