神奇算式(蓝桥杯真题)——python

题目如下:
由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

你可能感兴趣的:(python,python)