#BZOJ2912. Jump
Jump
题目描述
在一个无限长的棋盘上玩一种跳棋游戏,其中棋盘被划分成许多区域,每一个区域中可以放置多个的棋子。规定某一个区域的编号为0,在它开始往左边连续的区域编号为-1,-2,-3,…,在它的右边连续区域编号为1,2,3,…,若区域P有棋子,那么棋子有两种跳法:
向左跳:则方格P-1和P-2中应增加一枚棋子,方格P中应减少一枚棋子。
向右跳:则方格P和P+1中应减少一枚棋子,方格P+2中应增加一枚棋子。
对于给定的初始棋局,经过若干步跳棋后,总可以找到一种目标,就是任意两个相邻的区域棋子数目不超过1。
你的任务是对给定的一种初始棋局,找到最终的目标棋局。
输入格式
第一行为一个正整数n, 1 <= n <= 10000, 表示棋盘中放置棋子的状态数,下面的n行描述了每个状态,由两个用空格分隔的整数组成,第一个整数表示区域的位置(不超过10000),第二个整数表示该区域放置的棋子数目(不超过100000000).
输出格式
写入最终的棋局,这一行包含若干个整数,其中每一个整数为有棋子的区域编号,所有的区域按从小到大排列。
2
0 5
3 3
-4 -1 1 3 5