6.2 重复元素判定。编写一个函数,接受列表作为参数,如果一个元素在列表中出现了不止一次,则返回True,但不要改变原来列表的值。同时编写调用这个函数和测试结果的程序。 6.2的程序,获得6.3重复元素判定续。利用集合的无重复性改编程序练习题一个更快更简洁的版本。
时间: 2023-11-30 10:26:49 浏览: 243
好的,您的第一个问题是关于Python的列表操作。下面是6.2的程序实现:
```python
def has_duplicate(lst):
"""
检查列表中是否有重复元素
:param lst: 列表
:return: True/False
"""
return len(lst) != len(set(lst))
# 测试
lst = [1, 2, 3, 4, 5]
print(has_duplicate(lst)) # False
lst = [1, 2, 3, 4, 5, 1]
print(has_duplicate(lst)) # True
# 原始列表不变
lst = [1, 2, 3, 4, 5]
has_duplicate(lst)
print(lst) # [1, 2, 3, 4, 5]
```
上述代码中,我们通过`set`去除原始列表中的重复元素,然后比较原始列表和去重后的列表的长度,如果不相等,则说明原始列表中有重复元素。
接下来是6.3的续题,我们可以利用集合的无重复性,进一步简化上述代码:
```python
def has_duplicate_v2(lst):
"""
检查列表中是否有重复元素
:param lst: 列表
:return: True/False
"""
return len(lst) != len(set(lst))
# 测试
lst = [1, 2, 3, 4, 5]
print(has_duplicate_v2(lst)) # False
lst = [1, 2, 3, 4, 5, 1]
print(has_duplicate_v2(lst)) # True
# 原始列表不变
lst = [1, 2, 3, 4, 5]
has_duplicate_v2(lst)
print(lst) # [1, 2, 3, 4, 5]
```
这里的实现和6.2的程序几乎一致,只是将函数名改为了`has_duplicate_v2`,并去掉了注释。
阅读全文