比赛场次 | 137 |
---|---|
比赛名称 | 20120613 |
比赛状态 | 已结束比赛成绩 |
开始时间 | 2012-06-13 14:30:00 |
结束时间 | 2012-06-13 18:30:00 |
开放分组 | 全部用户 |
注释介绍 |
题目名称 | 表达式 |
---|---|
输入输出 | expressb.in/out |
时间限制 | 1000 ms (1 s) |
内存限制 | 128 MiB |
测试点数 | 10 简单对比 |
用户 | 结果 | 时间 | 内存 | 得分 |
---|---|---|---|---|
QhelDIV | AAWWWAWAWA | 0.000 s | 0.00 MiB | 50 |
Citron酱 | WWWWWWWWWA | 0.000 s | 0.00 MiB | 10 |
“#”这个操作符被定义为一个双目运算符,且两个运算对象为正整数,对于整数X、Y,“#”号运算定义为(X#Y)=(X各位数字和)*(Y各位数字中最大数字)+(Y各位数字中最小数字)。例:
(9#30)=9*3+0=27
(30#9)=3*9+9=36
关于表达式,我们约定或是一个正整数或是(表达式#表达式),一个表达式中只有相同的正整数。以下表达式是合法的表达式:
A (A#A) ((A#A)#A) (A#(A#A)#(A#A)#A)
对于给定的十进制正数A和表达式的值K,计算具有K值的表达式中“#”的个数。具有K值的表达式可能有许多,并且具有不同的“#”个数,只需输出最小个数。
本题有多组数据。
输入第一行一个正整数T表示数据组数,接下来依次给出每组数据。
每组数据包含两行,第一行只包含一个正整数描述A,第二行只包含一个非负整数描述K。
输出包含T行,每行一个非负整数表示相应数据组的答案,若无解这一行就输出-1。
3 2 6 3 7 1 87
1 2 16
本题包含10个测试点,对于每个测试点,如果你的输出和标准输出完全一样则得到该测试点的全部分数,否则得0分。
T ≤ 100
A ≤ 2 000 000 000
K ≤ 2 000 000 000