Python每日一练
问题:
编写一个Python程序,用于确定一个数字列表的乘积是否可以被该列表的和整除。
定义函数is_product_divisible_by_sum()的函数,该函数接受一个整数列表作为参数。
在函数内,如果列表中所有数字的乘积可以被该列表的和整除,则返回True,否则返回False。
题目来源:PythonTip
https://edu.py2fun.com/
代码实现
代码如下(示例):
def is_product_divisible_by_sum(numbers_list):
# 此处编写代码
pro = 1
sum1 = 0
for i in numbers_list: # 利用for循环求列表的和与积是常用的方法,此外我们还可以用Python内置函数sum求和,或使用numpy库封装的方法求列表和与积
pro = pro * i
for j in numbers_list:
sum1 = sum1 + j
if pro % sum1 == 0: # 取余操作,如果余数为0则两个数可以被整除
return True
else:
return False
# 获取整数输入并将其转换为列表
numbers_list = list(map(int, input().split()))
# 调用函数打印结果
print(is_product_divisible_by_sum(numbers_list))
示例输入:
1 2 3
示例输出:
True
总结
本段代码的思路并没有什么特别值得思考的地方,顺着逻辑写就行了,无论是列表求和还是求积,还是最后两个数整除的判定,都是很简单的编程思路。值得一提的是,本题的输入是以空格为分割的数值输入,依旧是input()函数输入,得到的是" 1 2 3"的字符串,然后利用split()分割空格,要强调的一点,split()返回的是一个列表,split()函数使用方法如下:
# 分割空格
s = '1 2 3'
print(s.split())
示例输出:
[‘1’, ‘2’, ‘3’]
# 分割斜线
s = '1/2/3'
print(s.split('/'))
示例输出:
[‘1’, ‘2’, ‘3’]
此外,我们再介绍一下每日一练中多次出现的map()函数。
map()函数是Python中的一个内置函数,它的功能是:将指定的函数,依次作用于可迭代对象的每个元素,并返回一个迭代器对象。这个可迭代对象,可以是一个也可以是多个。第一个参数是一个映射(函数),第二,第三个参数则是输入的可迭代对象。map会自动的依次取出可迭代对象中的每个元素,通过映射输出。我们可以直接将返回的迭代对象转化为list获取全部元素,或是通过map. ___ next___ ()控制获取每一个元素,使用方法如下:
# 转化为list获取全部元素
s = ['1', '2', '3']
s1 = list(map(int,s))
print(s1)
示例输出:
[1, 2, 3]
# 通过map. ___ next___ ()控制获取元素
s = ['1', '2', '3']
s1 = map(int,s)
for i in range(len(s)):
print(s1.__next__())
示例输出:
1
2
3