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")
相关推荐
浪客灿心13 分钟前
项目篇:模块设计与实现
数据库·c++
牛油果子哥q25 分钟前
【C++ STL vector】C++ STL vector 终极精讲:动态数组底层原理、两倍扩容机制、迭代器失效、增删查改、性能剖析与工程避坑指南
开发语言·c++
happymaker06261 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊2 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
为何创造硅基生物2 小时前
独占指针的创建std::make_unique 本身自带堆出现
c++
kyle~2 小时前
ROS 2 与 Isaac Sim 联合仿真(一)体系架构、环境选型与基础通信闭环
c++·机器人·nvidia·仿真·ros2
努力努力再努力wz3 小时前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
八解毒剂3 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
运行时记录4 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
起床困难户5754 小时前
条款20:协助完成返回值优化
c++