最新公告
  • 欢迎您光临信息学奥赛网,一个优质的信息学编程题库和信息学编程学习资源专业网站。欢迎加入VIP
  • 最小绝对和

    正文概述 陈老师   2026-01-20 15:14:39  

    题目描述

    YuuYuu 正在尝试加入学生会!不幸的是,她被要求去做文书工作…… ToukoTouko 要她填写各种学生会文件中的空白。

    给你一个部分填充的非负整数数组 a1,a2,,ana_1, a_2, \dots, a_n,其中未填写的元素用 1-1 表示。你想要用非负整数填补这些空白元素,使得其差分数组所有元素之和的绝对值最小。

    更正式地,令 bb 为长度为 n1n-1 的数组,满足对所有 1in11\leq i\leq n-1,都有 bi=ai+1aib_i = a_{i+1} - a_i。请在所有可能填充 aa 的方案中,求出 b1+b2++bn1|b_1 + b_2 + \dots + b_{n-1}| 的最小值。

    此外,输出能够达到这个最小值的数组。如果有多种这样的数组,请输出字典序最小的那一个 ^{\text{∗}}

    ^{\text{∗}} 对于两个长度为 nn 的任意数组 ccdd,当存在某个下标 ii1in1 \leq i \leq n),满足对于所有 j<ij<i,都有 cj=djc_j = d_j,且 ci<dic_i < d_i,则称 cc 的字典序小于 dd。换言之,ccdd 至少有一个位置不同,且在第一个不同的位置,cic_i 小于 did_i

    输入格式

    第一行包含一个整数 tt1t1041 \leq t \leq 10^4)——表示测试用例数量。

    每个测试用例的第一行包含一个整数 nn2n21052 \leq n \leq 2 \cdot 10^5)。

    每个测试用例的第二行包含 nn 个整数 a1,a2,,ana_1, a_2, \dots, a_n1ai106-1 \leq a_i \leq 10^6)。

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

    输出格式

    对于每个测试用例,第一行输出最小可能的 b1+b2++bn1|b_1 + b_2 + \dots + b_{n-1}|。第二行输出 nn 个整数,表示达到最小值的 a1,a2,,ana_1, a_2, \dots, a_n(字典序最小的那组)。

    样例

    6
    4
    2 -1 7 1
    4
    -1 2 4 -1
    8
    2 -1 1 5 11 12 1 -1
    3
    -1 -1 -1
    3
    2 5 4
    2
    -1 5
    
    1
    2 0 7 1
    0
    0 2 4 0
    0
    2 0 1 5 11 12 1 2
    0
    0 0 0
    2
    2 5 4
    0
    5 5
    

    提示

    样例解释

    在第一个样例中,我们将数组填成 a=[2,0,7,1]a = [2, 0, 7, 1],其差分数组为 b=[2,7,6]b = [-2, 7, -6]

    b b 所有元素之和的绝对值为 11。可以证明这是最小可能值。同时可以证明这是字典序最小的 aa

    信息学奥赛网,一个优质的信息学奥赛学习资源平台!
    信息学奥赛网 » 最小绝对和