鱼C论坛

 找回密码
 立即注册
查看: 917|回复: 3

小白求助

[复制链接]
发表于 2019-5-25 09:39:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回文素数是指一个数既是素数又是回文数,例如131既是素数又是回文数。编写程序打印输出前100个回文素数。要求每行打印输出10个,判断素数和实现反序数都用函数实现。

这个题目怎么写啊!!
在线等,挺急的!!!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-5-25 10:47:26 | 显示全部楼层
  1. def isPrime(n):
  2.     for i in range(3, int(n ** 0.5) + 2):
  3.         if n % i == 0:
  4.             return False
  5.     return True

  6. print(2, end = '\t')
  7. n = 3
  8. num = 1
  9. count = 1
  10. while True:
  11.     if isPrime(n) and str(n) == str(n)[:: -1]:
  12.         print(n, end = '\t')
  13.         count += 1
  14.         num += 1
  15.     if num > 100:
  16.         break
  17.     n += 2
  18.     if count >= 10:
  19.         count = 0
  20.         print()
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-25 11:01:07 | 显示全部楼层
先构思怎么写。
比如:
2、回文数怎么实现
3、素数怎么实现
4、实现打写前100个回文素数

  1. import math


  2. def palindromic_num(n):
  3.     n1 = list(n)
  4.     n2 = list(reversed(n1))
  5.     if n1 == n2:
  6.         return True
  7.     else:
  8.         return False


  9. #运用math函数 来判断素数
  10. def isPrime(n):   
  11.     if n <= 1:   
  12.         return False   
  13.     for i in range(2, int(math.sqrt(n)) + 1):   
  14.         if n % i == 0:   
  15.             return False   
  16.         return True
  17. '''
  18. #不使用模块的方法      
  19. def isPrime(n):   
  20.     if n <= 1:   
  21.         return False   
  22.     i = 2   
  23.     while i*i <= n:   
  24.         if n % i == 0:   
  25.             return False   
  26.     i += 1   
  27.     return True
  28. '''

  29. i = 1
  30. c = 0
  31. while True:
  32.    
  33.     if palindromic_num(str(i)) and isPrime(i):
  34.         print(i)
  35.         if c == 100:
  36.             break
  37.         c += 1

  38.     i += 1
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-5-25 14:15:50 | 显示全部楼层
写个生成器版的
  1. def numb():
  2.     n = 1
  3.     while True:
  4.         yield n
  5.         n += 2
  6. y = numb()
  7. def su():
  8.     while True:
  9.         x = next(y)
  10.         s = 0
  11.         for i in range(2,x):
  12.             if x% i ==0:
  13.                 break
  14.         else:
  15.             s = x
  16.         if s!=0:
  17.             return s
  18.         else:
  19.             continue

  20. for i in range(100):
  21.     yy = su()
  22.     if str(yy) == str(yy)[::-1]:
  23.         print(yy)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2026-1-15 23:54

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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