下面是一个示例代码,用于比较两个列表的列表,并只保留匹配的元素,同时保持结构不变:
def compare_lists(list1, list2):
# 创建一个空列表,用于存储匹配的元素
matched_elements = []
# 遍历第一个列表的子列表
for sublist1 in list1:
# 遍历第二个列表的子列表
for sublist2 in list2:
# 如果两个子列表相等,则将其添加到匹配的元素列表中
if sublist1 == sublist2:
matched_elements.append(sublist1)
# 返回匹配的元素列表
return matched_elements
# 示例输入
list1 = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
list2 = [[4, 5, 6], [10, 11, 12], [1, 2, 3]]
# 调用函数进行比较并保留匹配的元素
matched_elements = compare_lists(list1, list2)
# 输出结果
print(matched_elements)
输出结果:
[[4, 5, 6], [1, 2, 3]]
在上面的示例中,我们定义了一个名为compare_lists
的函数,该函数接受两个参数:list1
和list2
。我们使用两个嵌套的for
循环遍历list1
和list2
的子列表,并使用==
运算符比较它们是否相等。如果两个子列表相等,我们将其添加到matched_elements
列表中。最后,我们返回matched_elements
列表作为结果。
在示例输入中,list1
包含三个子列表,而list2
包含三个子列表。根据示例输入,我们期望输出的结果是匹配的子列表[[4, 5, 6], [1, 2, 3]]
。这是因为[4, 5, 6]
和[1, 2, 3]
是list1
和list2
中唯一相同的子列表。