给定列表ls=[25, 68,131,18, 11, 17, 7, 14, 13, 15],把列表ls中的非素数取出来并计算这个非素数的各位数字和放入新列表要求输出原列表和新列表。 ls=[25, 68, 18, 11, 17, 7, 14, 13, 15],新列表为newls=[7, 14, 9, 5, 6] 注意:列表使用输出函数直接输出即可,先输出原列表,再输出新列表。 将示例代码完整拷贝到你的程序,在注释标记处插入你自己编写的部分,ls列表内的元素值可以任意修改,但不得修改列表名。 ls=[25, 68, 18, 11, 17, 7, 14, 13, 15] #insert your code here
时间: 2023-09-23 16:11:19 浏览: 80
ls = [25, 68, 18, 11, 17, 7, 14, 13, 15]
newls = []
# 判断一个数是否为素数
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
# 遍历ls列表,取出非素数并计算各位数字和放入新列表
for num in ls:
if not is_prime(num):
digit_sum = sum(int(digit) for digit in str(num))
newls.append(digit_sum)
# 输出原列表和新列表
print("原列表:", ls)
print("新列表:", newls)
相关问题
python给定列表ls=[25, 68,131,18, 11, 17, 7, 14, 13, 15],把列表ls中的非素数取出来并计算这个非素数的各位数字和放入新列表要求输出原列表和新列表。 ls=[25, 68, 18, 11, 17, 7, 14, 13, 15],新列表为newls=[7, 14, 9, 5, 6] 注意:列表使用输出函数直接输出即可,先输出原列表,再输出新列表。 将示例代码完整拷贝到你的程序,在注释标记处插入你自己编写的部分,ls列表内的元素值可以任意修改,但不得修改列表名。 ls=[25, 68, 18, 11, 17, 7, 14, 13, 15] #insert your code here
ls = [25, 68, 18, 11, 17, 7, 14, 13, 15]
newls = []
# 判断是否为素数的函数
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
# 遍历列表,判断是否为素数,如果不是素数则计算各位数字和并放入新列表
for num in ls:
if not is_prime(num):
digit_sum = sum([int(digit) for digit in str(num)])
newls.append(digit_sum)
# 输出原列表和新列表
print("原列表:", ls)
print("新列表:", newls)
给定列表 ls = [9,8,7,6,5,4,3,2,1],将ls中大于3小于7的元素平方后返回为列表对象,采用lambda, filter,列表推导式联合实现。
可以使用以下代码实现:
```python
# lambda函数实现
result1 = list(map(lambda x: x ** 2, filter(lambda x: 3 < x < 7, ls)))
# 列表推导式实现
result2 = [x ** 2 for x in ls if 3 < x < 7]
# 结果验证
print(result1) # 输出 [36, 49]
print(result2) # 输出 [36, 49]
```
其中,lambda函数结合map和filter函数,map函数将筛选出的元素平方后返回,再使用list函数将结果转换为列表对象;列表推导式直接在列表中进行筛选和平方操作。最终的结果均为[36, 49],符合要求。
阅读全文