CF1635B.Avoid Local Maximums

传统题 时间 2000 ms 内存 256 MiB 3 尝试 1 已通过 1 标签

Avoid Local Maximums

题目描述

给定一个大小为 nn 的数组 aa,数组中的每个元素都是 1110910^9 之间的整数。

你可以对该数组进行若干次操作。每次操作时,你可以将数组中的任意一个元素替换为 1110910^9 之间的任意整数。

请输出使得最终数组中不包含任何局部极大值所需的最少操作次数,以及操作后的数组。

如果某个元素 aia_i 严格大于它的两个相邻元素(即 ai>ai1a_i > a_{i-1}ai>ai+1a_i > a_{i+1}),则称 aia_i 是一个局部极大值。由于 a1a_1ana_n 只有一个相邻元素,因此它们永远不会是局部极大值。

输入格式

每个测试包含多组测试用例。第一行包含一个整数 tt (1t10000)(1 \leq t \leq 10000),表示测试用例的数量。接下来是 tt 组测试用例。

每组测试用例的第一行包含一个整数 nn (2n2105)(2 \leq n \leq 2 \cdot 10^5),表示数组 aa 的大小。

第二行包含 nn 个整数 a1,a2,,ana_1, a_2, \ldots, a_n (1ai109)(1 \leq a_i \leq 10^9),表示数组的元素。

保证所有测试用例中 nn 的总和不超过 21052 \cdot 10^5

输出格式

对于每个测试用例,首先输出一行一个整数 mm,表示所需的最少操作次数。然后输出一行 nn 个整数,表示操作后的数组。注意,该数组与初始数组恰好有 mm 个元素不同。

如果有多种答案,输出任意一种均可。

说明/提示

在第一个样例中,数组中没有局部极大值,因此不需要进行任何操作。

在第二个样例中,可以将 a2a_2 改为 33,此时数组中没有局部极大值。

由 ChatGPT 4.1 翻译

样例

5
3
2 1 2
4
1 2 3 1
5
1 2 1 2 1
9
1 2 1 3 2 3 1 2 1
9
2 1 3 1 3 1 3 1 3
0
2 1 2
1
1 3 3 1
1
1 2 2 2 1
2
1 2 3 3 2 3 3 2 1
2
2 1 3 3 3 1 1 1 3

在线编程 IDE

建议全屏模式获得最佳体验