鱼C论坛

 找回密码
 立即注册
查看: 926|回复: 2

[已解决]回文素数

[复制链接]
发表于 2020-5-14 17:51:08 | 显示全部楼层 |阅读模式
10鱼币
现在在外面没有电脑晚上一遍写一遍看你们的回复给最佳嘤嘤嘤
最佳答案
2020-5-14 17:51:09
  1. def func(n):
  2.   cnt = 0
  3.   i = 2
  4.   while cnt < n:
  5.     for j in range(2, i):
  6.       if i % j == 0:
  7.         break
  8.     else:
  9.       if str(i)[::-1] == str(i):
  10.         print(i)
  11.         cnt += 1
  12.     i += 1

  13. n = int(input("请输入一个数字:"))
  14. func(n)
复制代码
QQ图片20200514175011.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-5-14 17:51:09 | 显示全部楼层    本楼为最佳答案   
  1. def func(n):
  2.   cnt = 0
  3.   i = 2
  4.   while cnt < n:
  5.     for j in range(2, i):
  6.       if i % j == 0:
  7.         break
  8.     else:
  9.       if str(i)[::-1] == str(i):
  10.         print(i)
  11.         cnt += 1
  12.     i += 1

  13. n = int(input("请输入一个数字:"))
  14. func(n)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-5-14 18:22:48 | 显示全部楼层
  1. a = int(input())
  2. b = []   #赋值空列表,后续假如计算得出的回文素数
  3. n = 1    #初始值
  4. while len(b) < a:   #若列表得出的回文数小于目标,循环执行
  5.     n = n+1   #每次循环测试的数+1
  6.     if str(n) == str(n)[::-1]:  #比较是否回文数
  7.         for i in range(1,n):    #遍历循环 除去本身 求余数判断是否素数
  8.             if n % i == 0:
  9.                 x = i          #得出循环完最大的余数
  10.         else:
  11.             if x == 1:    #根据素数的特性 除本身之外公因数只有1
  12.                 b.append(str(n))#append方法将所得回文素数加入列表
  13. print("{}".format(" ".join(b)),end=" ")  #join方法将最后列表转为字符串
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-19 06:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表