鱼C论坛

 找回密码
 立即注册
查看: 2895|回复: 0

[技术交流] 0007-编程打卡:将正整数分解质因数

[复制链接]
发表于 2022-8-23 17:38:18 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 不二如是 于 2022-8-29 17:47 编辑

01.png
02.png
03.png
04.png

一星答案:

  1. from math import *
  2. #判断n是否为素数
  3. def isprime(n):
  4.     if n <= 1:
  5.         return 0
  6.     m = int(sqrt(n))+1
  7.     for x in range(2,m):
  8.         if n%x == 0:
  9.             return 0
  10.     return 1
  11. #利用递归分解n并打印质因数
  12. def bprime(n):
  13.     if isprime(n):
  14.         print(n)
  15.     else:
  16.         x = 2
  17.         while x <= int(n/2):
  18.             if n%x == 0:
  19.                 print(x)
  20.                 return bprime(n/x)
  21.             x = x + 1
复制代码



二星答案:

  1. #利用递归
  2. def fishc(n, lst=[]):
  3.     primes = [True] * int(n**0.5 + 1)
  4.     primes[0], primes[1] = False, False
  5.     for i, prime in enumerate(primes):
  6.         if prime:
  7.             for j in range(i * i, int(n**0.5 + 1), i):
  8.                 primes[j] = False
  9.     primelist = [i for i, prime in enumerate(primes) if prime]
  10.     for p in primelist:
  11.         if n % p == 0:
  12.             return fishc(n / p, lst + [p])
  13.     return lst + [n]
复制代码



三星答案:

游客,如果您要查看本帖隐藏内容请回复


基础语法:



算法讲解:





评分

参与人数 1荣誉 +5 贡献 +3 收起 理由
睦ちゃん她爹 + 5 + 3 鱼C有你更精彩^_^

查看全部评分

本帖被以下淘专辑推荐:

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-9 13:10

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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