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分析

思路

这个问题的核心是,我们需要遍历数组中所有出现过的数字,将它们逐一作为候选的目标数字 xxx,然后计算每种情况下所需的最小操作次数,最后在所有候选结果中取一个最小值。

那么,当我们选定了一个目标数字 xxx 后,如何计算最少操作次数呢?

根据题意,操作是移除不包含 xxx 的连续区间。这意味着所有不等于 xxx 的元素都必须被移除。这些需要被移除的元素,被数组中原有的 xxx 分隔成了若干个“连续块”。

例如,对于样例 [1, 2, 3, 1, 4, 5, 1],如果我们选择 x=1x=1x=1,那么数组可以看作:

P3549.第1题-数组清理

    1000ms Tried: 129 Accepted: 42 Difficulty: 3 所属公司 : 百度
    算法与标签>思维

题目内容

现在有一个长度为 nnn 的数组。现在小明希望从数组中挑选一个数字 xxx ,通过做一种清理操作,将原数组中的一些数字移除,使得最终数组中的数字都等于 xxx 。这种移除操作一次可以删除数组中一段连续区间,但是这个区间中不能有任何数字等于 xxx 。小明想知道对于一个数组,他最少需要多少次移除操作完成目标。

输入描述

第一行一个整数 n(3<=n<=100000)n(3<=n<=100000)n(3<=n<=100000)

第二行 nnn 个整数,表示数组中的数字,数字范围在 [1,100000][1,100000][1,100000] 。

输出描述

一个整数,表示最少所需的操作次数。

样例1

输入

7
1 2 3 1 4 5 1

输出

2

说明

其中一种方法为,挑选 x=1x=1x=1 ,一次删除 2,32,32,3 ,一次删除 4,54,54,5

登录后即可使用 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 2, 163ms
  3. Powered by Hydro v5.0.0-beta.18 Community
CLOSE


ScanQRCodePrompt

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

Forgot password or username?