USACO 1.4 Python3 Prime Cryptarithm

"""
ID: ***
LANG: PYTHON3
TASK: crypt1
"""
fin = open ('crypt1.in', 'r')
fout = open ('crypt1.out', 'w')
N = int(fin.readline())
numS = 0
digits = list(map(int,fin.readline().split()))
#print(digits)
abc = list()
de = list()
def ifQualified(product, digits) -> bool:
    for x in range(len(str(product))):
        if int(str(product)[x]) not in digits:
            return False
    return True

#'abc'
for a in range(N):
    for b in range(N):
        for c in range(N):
            abc.append(int("{}{}{}".format(digits[a],digits[b],digits[c])))

for d in range(N):
    for e in range(N):
        de.append(int("{}{}".format(digits[d],digits[e])))
for x in range(len(abc)):
    for y in range(len(de)):
        e = de[y]%10
        d = de[y]//10
        eabc = e*abc[x]
        dabc = d*abc[x]
        deabc = de[y]*abc[x]
        if len(str(dabc))>3 or len(str(eabc))>3:
            continue
        if ifQualified(eabc, digits) and ifQualified(dabc, digits) and ifQualified(deabc, digits):
            numS += 1
            #print(abc[x], de[y], deabc)

fout.write("{}\n".format(str(numS)))
fout.close()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值