这题不会,麻烦用最简单的调用函数的方法解答一下

 

def isPrime(n):
    for i in range(2, int(pow(n,1/2))+1):
        if n%i == 0:
            return False
    return True

def isHuiwen(n):
    s = str(n)
    k = len(s)//2
    return s[:k] == s[-k:][::-1]

n = 11
primes = list()

while len(primes) < 50:
    if isPrime(n) and isHuiwen(n):
        primes.append(n)
    n += 1

for i in range(7):
    for j in range(8):
        k = i*8+j
        if k < 50:
            print(('%d'%primes[k]).ljust(8), end='')
    print()

 

执行结果:

您好,我是有问必答小助手,您的问题已经有小伙伴解答了,您看下是否解决,可以追评进行沟通哦~

如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~

ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632

非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!

速戳参与调研>>>https://t.csdnimg.cn/Kf0y

i = 10
HuiWenSu =[]
JieGuo = []
#筛选回文数
while i <= 100000:
    ZiFu = str(i)
    FanZhuan = ZiFu[::-1]
    HuiWen = int(FanZhuan)
    if HuiWen == i:
        HuiWenSu.append(HuiWen)
    i += 1
#在筛选出来的回文数中筛选符合条件的素数
for Hui in HuiWenSu:
    a = 2
    while a < Hui:
        if Hui % a == 0:
            break
        elif a+1 == Hui:
            JieGuo.append(Hui)
            a += 1
        else:
            a += 1

print(JieGuo)