如何解决用一行代码从两个单独的列表生成一个新列表
我正在尝试一项需要您进行的练习:
编写一个程序,返回一个只包含元素的列表 列表之间很常见(没有重复)。确保您的 程序适用于两个不同大小的列表。
我能够做到这一点,但额外的挑战之一是:
用一行 Python 写这个
我想出了以下代码:
list_1 = [1,1,2,3,89]
list_2 = [1,4,5,6,7,8,9,10,13]
newList = []
newList = [x for x in list_1 if x in list_2 if x not in newList] #attempting one line
print(newList)
newList = []
for x in list_1:
if x in list_2 and x not in newList:
newList.append(x)
print(newList)
我得到以下结果:
[1,3]
[1,3]
我的单行列表理解似乎失败了,有人能指出这是为什么吗?
解决方法
一种基本的方法是将 newList 转换为 set 然后将其重新转换为 list
print(list(set(newList)))
或者使用没有任何循环的集合交集
print(list(set(list_1).intersection(list_2)))
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。