#ATarc135b. [ARC135B] Sum of Three Terms

[ARC135B] Sum of Three Terms

题目描述

给定一个项数为 NN 的整数列 S=(S1,,SN)S = (S_1, \ldots, S_N)。请判断是否存在一个项数为 N+2N+2 的整数列 A=(A1,,AN+2)A = (A_1, \ldots, A_{N+2}),满足以下条件:

  • 对于任意的 ii1iN+21 \leq i \leq N+2),都有 0Ai0 \leq A_i
  • 对于任意的 ii1iN1 \leq i \leq N),都有 Si=Ai+Ai+1+Ai+2S_i = A_i + A_{i+1} + A_{i+2}

如果存在,请输出其中一种满足条件的 AA

输入格式

输入从标准输入中给出,格式如下:

NN S1S_1 S2S_2 \ldots SNS_N

输出格式

如果存在满足条件的整数列 AA,输出 Yes,否则输出 No。如果输出 Yes,则在第二行输出满足条件的整数列 AA 的各个元素,空格分隔。

A1A_1 A2A_2 \ldots AN+2A_{N+2}

如果存在多组满足条件的解,输出任意一组均可。

样例 1

输入

5
6 9 6 6 5

输出

Yes
0 4 2 3 1 2 2

样例 2

输入

5
0 1 2 1 0

输出

No

样例 3

输入

1
10

输出

Yes
0 0 10

说明/提示

数据范围

  • 1N3×1051 \leq N \leq 3 \times 10^5
  • 0Si1090 \leq S_i \leq 10^9

样例解释 1

可以验证,对于任意的 ii1iN1 \leq i \leq N),都有 Si=Ai+Ai+1+Ai+2S_i = A_i + A_{i+1} + A_{i+2} 成立。

  • 6=0+4+26 = 0 + 4 + 2
  • 9=4+2+39 = 4 + 2 + 3
  • 6=2+3+16 = 2 + 3 + 1
  • 6=3+1+26 = 3 + 1 + 2
  • 5=1+2+25 = 1 + 2 + 2

由 ChatGPT 4.1 翻译