问题描述
请看下面的算式:
(ABCD - EFGH) * XY = 900
每个字母代表一个0~9的数字,不同字母代表不同数字,首位不能为0。
比如,(5012 - 4987) * 36 就是一个解。
请找到另一个解,并提交该解中 ABCD 所代表的整数。
请严格按照格式,通过浏览器提交答案。
注意:只提交 ABCD 所代表的整数,不要写其它附加内容,比如:说明性的文字。
思路分析及代码实现
把数字全排列排除0在首位的,剩下填充就行了最后判断是否等于900
for i in li:
if i[0] != 0 and i[4] != 0 and i[8] != 0:
x = i[0]*1000+i[1]*100+i[2]*10+i[3]
y = i[4]*1000+i[5]*100+i[6]*10+i[7]
z = i[8]*10+i[9]
if (x-y)*z == 900:
print(i)
print(x)
答案:6048