已知一个list,求这个list中每一个元素是否是其他元素的子元素,如果是,则删除这个元素.list = ['GH', 'ACDB', 'AB', 'ABCFE', 'ABDCFE', 'ACFE', 'ABCD', 'ABD', 'ACBD', 'ACD', 'FCBA', 'FCDBA', 'FCA', 'FC', 'BACF', 'BCF', 'BDCF', 'BACFE', 'BCFE', 'BDCFE', 'BACD', 'BCD', 'BD', 'CBA', 'CDBA', 'CA', 'CAB', 'CDB', 'CB', 'EF', 'EFC', 'EFCABD', 'EFCBD', 'EFCD', 'DBACF', 'DBCF', 'DCF', 'DBAC', 'DBC', 'DC']如上段代码,最后list应该剩下的元素是list=['ABDCFE','GH']
2 回答
千巷猫影
TA贡献1829条经验 获得超7个赞
def get_without_proper_sub_element(s): def is_proper_sub_element(i): for j in s: if set(i).issubset(set(j)) and set(i) != set(j): return True return False return [i for i in s if not is_proper_sub_element(i)] print(get_without_proper_sub_element(s))
结果是:
['GH', 'ABDCFE', 'EFCABD'] 这里面的后面两个'ABDCFE'和'EFCABD'根据现有描述是都要保留的, 除非要求按顺序只保留第一个.
添加回答
举报
0/150
提交
取消