python练习题17:求100以内的素数和

这篇博客介绍了如何使用Python计算100以内所有素数的和,提供了代码实现,并解释了不同方法的输出差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

描述

求100以内的素数之和并输出。


输入格式

该题目没有输入


输入输出示例

示例输入输出
示例1无(红色字体不是OJ的输入)说明:直接输出100以内的素数之和。(红色字体不是OJ的输出)

代码

num=100
i=2
qh=0
for i in range(2,100):
    j=2
    for j in range(2,i):
        if(i%j==0):
            break
    else:
        qh+=i
print(qh)

题目来源:python123.io


补充

获取100以内的素数(质数)

#方法一
num=[];
i=2
for i in range(2,100):
   j=2
   for j in range(2,i):
      if(i%j==0):
         break
   else:
      num.append(i)
print(num)

#方法二
import math
def func_get_prime(n):
  return list(filter(lambda x: not [x%i for i in range(2, int(math.sqrt(x))+1) if x%i ==0], range(2,n+1)))
print (func_get_prime (100))

#方法三
import math

N = 100 
print (list(p for p in range(2, N) if 0 not in ( p%i for i in range(2,int(math.sqrt(p))+1))))

python3版本
方法二、方法三需要引用list()转换成列表输出,要不然输出为:
方法二输出: <filter object at 0x0000029A9B8BD2B0>
方法三输出: <generator object <genexpr> at 0x00000278AEA74A98>

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值