题目如下:
由4个不同的数字,组成的一个乘法算式,它们的乘积仍然由这4个数字组成。
比如:
210 x 6 = 1260
8 x 473 = 3784
27 x 81 = 2187
都符合要求。
如果满足乘法交换律的算式算作同一种情况,那么,包含上边已列出的3种情况,一共有多少种满足要求的算式。
请填写该数字,通过浏览器提交答案,不要填写多余内容(例如:列出所有算式)。
我们可以直接枚举暴力求解,但是注意,他要求不让重复,我们第二次枚举前面第一次遍历的可以不用,直接从当前起点出发。限制是四位数我们可以直接写代码了
count = 0
for x in range(1, 999):
for y in range(x, 999):
if sorted(str(x*y)) == sorted(str(x) + str(y)) and len(str(x)+str(y)) == 4 and len(set(list(str(x*y)))) == 4:
print(f'{x}*{y}={x*y}')
count += 1
print(count)
3*501=1503
3*510=1530
6*201=1206
6*210=1260
8*473=3784
9*351=3159
15*93=1395
21*60=1260
21*87=1827
27*81=2187
30*51=1530
35*41=1435
12