编写一个接收数字列表的函数
和术语列表,只返回可分割的元素
通过所有这些条款.您必须使用两个嵌套列表推导来解决它.
divisible_numbers([12,11,10,9,8,7,6,5,4,3,2,1],[2,3])#返回[12,6]
def divisible_numbers(a_list,a_list_of_terms):
到目前为止,我有一个模糊的伪代码,包括检查清单,如果它附加到新列表,检查是否可分,检查新列表检查是否可以被下一个术语整除,并重复直到,你已经完成了所有条款,我不知道我想让任何人为我这样做,但也许是正确方向的暗示?
解决方法:
内部表达式应检查对于特定数字,该数字是否可被第二个列表中的所有术语整除
all(i%j==0 for j in a_list_of_terms)
然后是外部列表理解,以迭代第一个列表的项目
[i for i in a_list if all(i%j==0 for j in a_list_of_terms)]
全部一起
def divisible_numbers(a_list, a_list_of_terms):
return [i for i in a_list if all(i%j==0 for j in a_list_of_terms)]
测试
>>> divisible_numbers([12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1], [2, 3])
[12, 6]
标签:python,for-loop,math,list-comprehension
来源: https://codeday.me/bug/20190722/1504474.html