运用内置函数enumerate,运用内置函数filer编写程序,输入一个大于2的自然数,然后输出小于该数字的所有素数组成的列表。
时间: 2024-09-19 20:01:08 浏览: 27
基于jupyter notebook的python编程—–使用列表实现筛选法求素数(输入一个大于 2 的自然数,然后输出小于该数字的所有素数组成的列表)
5星 · 资源好评率100%
当然可以,我们可以使用Python的内置函数`enumerate()`遍历输入数字的因子,并结合`filter()`函数筛选出素数。以下是实现这一功能的一个示例程序:
```python
def is_prime(num):
"""检查一个数是否为素数"""
if num < 2:
return False
for i in range(2, int(num**0.5) + 1):
if num % i == 0:
return False
return True
def find_primes(n):
"""找出小于n的所有素数"""
primes = [i for i, v in enumerate(range(2, n)) if is_prime(v)]
return primes
# 输入一个大于2的自然数
input_num = int(input("请输入一个大于2的自然数: "))
primes_list = find_primes(input_num)
print(f"小于{input_num}的所有素数是: {primes_list}")
阅读全文