#USACO2277. 拍照

    ID: 756 Type: Default File IO: photo 1000ms 256MiB Tried: 7 Accepted: 2 Difficulty: 10 Uploaded By: Tags>USACO 2020 January Contest Bronze

拍照

题目描述

农夫约翰在给他编号为 1N 1…N N N 头奶牛排队拍照。

约翰一开始计划从左向右数第 i 个位置排编号为 ai a_i 的奶牛,他在一张纸上写下了排列a1,a2,,aN a_1,a_2,…,a_N

不幸的是,这张纸刚刚被小偷偷走了!

幸好约翰仍然有机会恢复他之前写下的排列。

在这张纸被偷走之前,奶牛贝茜记录了序列 b1,b2,,bN1 b_1,b_2,…,b_{N−1} ,对于每一个 1i<N 1≤i<N 满足 bi=ai+ai+1 b_i=a_i+a_{i+1}

基于贝茜的信息,帮助约翰恢复可以产生序列 b的“字典序最小”的排列 a a

排列 x x 字典序小于排列 y y :如果对于某个 j j ,对于所有i<j i<j 均有xi=yi x_i=y_i ,且有 xj<yj x_j<y_j

(换句话说,这两个排列到某个位置之前都相同,在这个位置上 x x 小于 y y )。

保证存在至少一个满足条件的 a a

输入

输入的第一行包含一个整数 N N

第二行包含 N1 N−1 个空格分隔的整数 b1,b2,,bN1 b_1,b_2,…,b_{N−1}

输出

输出一行,包含 N N 个空格分隔的整数 a1,a2,,aN a_1,a_2,…,a_N

样例输入

5
4 6 7 6

样例输出

3 1 5 2 4

提示

2N103 2≤N≤10^3

a a 能够产生 b b ,因为 3+1=4,1+5=6,5+2=7,2+4=6。