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")
相关推荐
BothSavage18 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn18 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽20 小时前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
郝学胜_神的一滴20 小时前
CMake 034:生成器表达式:解耦构建时序、精简分支逻辑的终极利器
c++·cmake
先吃饱再说1 天前
判断回文字符串,从一行代码到双指针优化
算法
见过夏天1 天前
C++ 基础入门完全指南
c++
黄敬峰2 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术2 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六2 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程