2013-04-17 14:34:39 +08:00

49 lines
911 B
Python

def alanum(x):
lis = []
while x != 0:
lis.append(x % 10)
x /= 10
return lis
def pick(x, lis, out, a = 0):
if x == 0:
out.append([a, lis])
return
a *= 10
for i in xrange(len(lis)):
tmp = lis[:]
tmpa = a + lis[i]
tmp.pop(i)
pick(x - 1, tmp, out, tmpa)
def isp(x):
if x == 2:
return True
if x <= 1 or x & 1 == 0:
return False
for i in xrange(3, int(x ** 0.5) + 1, 2):
if x % i == 0:
return False
return True
def main():
n = 1489
while 1:
if isp(n):
tmp = alanum(n)
ttmp = []
pick(4, tmp, ttmp)
tt = []
for ti in ttmp:
tt.append(ti[0])
#print n, tmp, tt
while tt.count(n) > 0:
tt.remove(n)
for ii in tt:
jj = 2 * ii - n
if jj > 0 and isp(ii) and isp(jj) and tt.count(jj):
return str(n) + str(ii) + str(jj) #(n, ii, jj)
n += 1
print main()