1. Job Roadmap
  2. Home
  3. Problem Set
  4. codenotelist
  5. Forum
  6. course
  7. Shore Share Sessions
  8. Record
  1. Login
  2. Sign Up
  3. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
    ZhContent TextSol AI分析

解题思路

题目中的“乱翘的数组”本质上要求:

  • 任意相邻元素不相等;
  • 对于每个中间位置,都必须同时严格大于两边,或者严格小于两边。

这等价于整个数组的相邻大小关系必须交替出现,也就是形如:

P4601.第2题-乱翘的数组hard

    1000ms Tried: 60 Accepted: 25 Difficulty: 5 所属公司 : 米哈游
    算法与标签>贪心算法

题目内容

对于给定的长度为 nnn 的数组 {a1,a2,...,ana_1,a_2,...,a_na1​,a2​,...,an​},我们定义“翘数”为同时严格大于或小于左右相邻数的数字。形式化的讲,对于第 i(1<i<n)i(1<i<n)i(1<i<n) 个整数 aia_iai​ ,它被称作“翘数”,当且仅当满足 ai−1<ai>ai+1a_{i-1}<a_i>a_{i+1}ai−1​<ai​>ai+1​ 或 ai−1>ai<ai+1a_{i-1}>a_i<a_{i+1}ai−1​>ai​<ai+1​ 。

若一个数组中,所有的满足 i∈(1,n)i∈(1,n)i∈(1,n) 的数字 aia_iai​ 均为“翘数”,且任意相邻的两个元素 aj,aj+1(1≤j<n)a_j,a_{j+1}(1≤j<n)aj​,aj+1​(1≤j<n) 都不相等,则称该数组为“乱翘的数组”。

现在,对于给定的初始数组,计算最少需要从原数组中删除的数字个数,使得剩余数字按原相对顺序拼接成的新数组是一个“乱翘的数组”。

输入描述

第一行输入一个整数 n(3≤n≤2×105)n(3≤n≤2×10^5)n(3≤n≤2×105) 代表数组中的元素数量。

第二行输入 nnn 个整数 a1,a2,...,an(−107≤ai≤107)a_1,a_2,...,a_n(-10^7≤a_i≤10^7)a1​,a2​,...,an​(−107≤ai​≤107) 代表数组元素。

输出描述

在一行上输出一个整数,代表最少需要删除的数字个数。

样例1

输入

7
1 3 1 4 5 2 0

输出

2

说明

其中一种最优的方案是删除数组中的第五、七个数字。

样例2

输入

3
2 2 2

输出

2

登录后即可使用 AI 分析。

模式
倒计时时长
:

最长 10 小时 59 分;应用后按此时长重新开始。

提示:点击提交记录在左侧题面区域查看详情
题库
AI分析设置
留空使用官方API Key,每天有次数限制(自定义API Key仅限会员和管理员使用,不限次数)
会员和管理员可切换模型;切到 Kimi/智谱/通义/豆包时需填写对应供应商 API Key
升级会员,可将运行与提交冷却时间缩短至 1 秒起

Status

  • Judging Queue
  • Service Status

Development

  • Open Source

Support

  • Help
  • Contact Us

About

  • About
  • Privacy
  • Terms of Service
  • Copyright Complaint
  1. Language
    1. English
    2. 한국어
    3. 简体中文
    4. 正體中文
  2. Legacy mode
  3. Theme
    1. Light
    2. Dark
  1. 京ICP备2025123107号-1
  2. Worker 0, 29ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

请使用微信扫描下方二维码完成注册

Forgot password or username?