鱼C论坛

 找回密码
 立即注册
查看: 1189|回复: 7

[已解决]设若我们不考虑效率问题,如何编写一个代码量最小的求素数的代码

[复制链接]
发表于 2020-6-24 09:11:32 | 显示全部楼层 |阅读模式

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

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

x
def issu(num):
    flag=1
    for j in range(2,num): 
        if num % j ==0:
            return 0
    return flag  
最佳答案
2020-6-24 09:32:04
wp231957 发表于 2020-6-24 09:30
还敢再精简一下吗

当然
issu = lambda num:all(map(lambda p:num % p != 0,range(2,num)))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-6-24 09:16:50 | 显示全部楼层
flag=1去掉一行,加入import math,如此行数不变,效率高了
import math
def issu(num):
    for j in range(2,int(math.sqrt(num)):
        if num % j ==0:
            return 0
    return 1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-24 09:18:43 | 显示全部楼层
def issu(num):
    for i in range(2,num):
        if num % i == 0:return False
    return True
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-6-24 09:30:00 | 显示全部楼层

还敢再精简一下吗
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-24 09:31:03 | 显示全部楼层

和菠菜的差不多哈哈,麻烦了点
def issu(num):
    for j in range(2,num):
        if num % j ==0:break
    return bool(num%j)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-24 09:32:04 | 显示全部楼层    本楼为最佳答案   
wp231957 发表于 2020-6-24 09:30
还敢再精简一下吗

当然
issu = lambda num:all(map(lambda p:num % p != 0,range(2,num)))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-6-24 09:39:46 | 显示全部楼层

这样也可行:
f = lambda num : [ num for i in range(2,num) if (num % i == 0)]
print(bool(f(3)))

评分

参与人数 1荣誉 +1 鱼币 +1 收起 理由
wp231957 + 1 + 1

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-6-24 09:44:26 | 显示全部楼层


嘿嘿 继续来个简单 :
f = lambda num : 1 if [ num for i in range(2,num) if (num % i == 0)] == [] else 0

评分

参与人数 1荣誉 +1 鱼币 +1 收起 理由
wp231957 + 1 + 1

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-20 07:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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