CF1120B.Once in a casino
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
One player came to a casino and found a slot machine where everything depends only on how he plays. The rules follow.
A positive integer a is initially on the screen. The player can put a coin into the machine and then add 1 to or subtract 1 from any two adjacent digits. All digits must remain from 0 to 9 after this operation, and the leading digit must not equal zero. In other words, it is forbidden to add 1 to 9 , to subtract 1 from 0 and to subtract 1 from the leading 1 . Once the number on the screen becomes equal to b , the player wins the jackpot. a and b have the same number of digits.
Help the player to determine the minimal number of coins he needs to spend in order to win the jackpot and tell how to play.
输入格式
The first line contains a single integer n ( 2≤n≤105 ) standing for the length of numbers a and b .
The next two lines contain numbers a and b , each one on a separate line ( 10n−1≤a,b<10n ).
输出格式
If it is impossible to win the jackpot, print a single integer −1 .
Otherwise, the first line must contain the minimal possible number c of coins the player has to spend.
min(c,105) lines should follow, i -th of them containing two integers di and si ( 1≤di≤n−1 , si=±1 ) denoting that on the i -th step the player should add si to the di -th and (di+1) -st digits from the left (e. g. di=1 means that two leading digits change while di=n−1 means that there are two trailing digits which change).
Please notice that the answer may be very big and in case c>105 you should print only the first 105 moves. Your answer is considered correct if it is possible to finish your printed moves to win the jackpot in the minimal possible number of coins. In particular, if there are multiple ways to do this, you can output any of them.
输入输出样例
输入#1
3 223 322
输出#1
2 1 1 2 -1
输入#2
2 20 42
输出#2
2 1 1 1 1
输入#3
2 35 44
输出#3
-1
说明/提示
In the first example, we can make a +1 operation on the two first digits, transforming number 223 into 333 , and then make a -1 operation on the last two digits, transforming 333 into 322 .
It's also possible to do these operations in reverse order, which makes another correct answer.
In the last example, one can show that it's impossible to transform 35 into 44 .