编写一个接收数字列表的函数 和术语列表,只返回可分割的元素 通过所有这些条款。您必须使用两个嵌套列表推导来解决它。
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):
到目前为止我有一个模糊的伪代码,它包含检查列表,如果它附加到新列表,检查是否可分,检查新列表检查是否可以被下一个术语整除,并重复直到,你已经完成了所有条款,我不希望任何人为我这样做,但也许是正确方向的暗示?
答案 0 :(得分:9)
内部表达式应检查对于特定数字,该数字是否可被第二个列表中的所有术语整除
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]