传统题 1000ms 256MiB

数列删除

该比赛已结束,您无法在比赛模式下递交该题目。您可以点击“在题库中打开”以普通模式查看和递交本题。

题目描述

给你一个长度为 n(1n500)n(1 \le n \le 500) 的数组 aa,每次你可以进行以下两步操作:

  • 找到两个数相邻且相等的数,ai=ai+1a_i=a_{i+1}
  • 它们 替换为 ai+1a_i + 1

每轮操作之后,显然数组的长度会减小 11,问剩余数组长度的最小值。

输入格式

第一行包含一个整数 n(1n500)n(1 \le n \le 500),表示数组的原长。

第二行包含 nn 个整数 a1,a2,an(1ai1000)a_1, a_2, \cdots a_n (1 \le a_i \le 1000),表示原数组 aa

输出格式

共一行仅一个整数 numnum,表示进行许多轮操作之后,aa 剩余长度的最小值。

样例解释

第一组样例中,最优操作之一为 $\text{4 3 2 2 3} \to \text{4 3 3 3} \to \text{4 4 3} \to \text{5 3}$

第二组样例中,最优操作之一为 $\text{3 3 4 4 4 3 3} \to \text{4 4 4 4 3 3} \to \text{4 4 4 4 4} \to \text{5 4 4 4} \to \text{5 5 4} \to \text{6 4}$

对于第三和第四组样例,你并不能进行任何操作。

5
4 3 2 2 3
2
7
3 3 4 4 4 3 3
2
3
1 3 5
3
1
1000
1

0315

未参加
状态
已结束
规则
XCPC
题目
6
开始于
2026-3-15 14:00
结束于
2026-3-15 17:21
持续时间
3.4 小时
主持人
参赛人数
82