python查找列中重复数字
时间: 2023-08-02 19:26:37 浏览: 68
您可以使用Python中的集合(set)数据结构来查找列表中的重复数字。以下是一个示例代码:
```python
my_list = [1, 2, 3, 4, 2, 3, 5, 6, 7, 7]
duplicates = set()
for num in my_list:
if my_list.count(num) > 1:
duplicates.add(num)
print(duplicates)
```
在这个例子中,我们首先定义一个包含重复数字的列表my_list。接下来,我们创建一个空的集合duplicates来存储重复数字。然后,我们遍历my_list中的每个数字,并使用count()函数来计算数字在my_list中出现的次数。如果数字出现的次数大于1,我们将其添加到duplicates集合中。最后,我们打印出duplicates集合,其中包含了my_list列表中的所有重复数字。
输出应该是:
```
{2, 3, 7}
```
这表示该列表中包含数字2、3和7的重复项。
相关问题
Python查找数列中重复数字
可以使用Python中的set()函数来查找数列中的重复数字。set()函数将列表转换为集合,集合中的元素是唯一的,因此可以使用集合的长度来判断列表中是否有重复元素。以下是示例代码:
```python
my_list = [1, 2, 3, 4, 5, 6, 3, 7, 8, 9, 1]
my_set = set(my_list)
if len(my_list) != len(my_set):
print("有重复数字")
else:
print("没有重复数字")
```
输出结果为:
```
有重复数字
```
这是因为数列中有重复的数字1和3。
python查找数列中重复数字的最后一个
可以使用以下代码来查找数列中重复数字的最后一个:
```python
def find_last_duplicate(nums):
last_duplicate = -1
seen = set()
for i in range(len(nums)-1, -1, -1):
if nums[i] in seen:
last_duplicate = i
else:
seen.add(nums[i])
return last_duplicate
```
这个函数的输入是一个包含数字的列表 `nums`,返回值是数列中最后一个重复数字的下标。如果数列中没有重复数字,则返回 -1。
函数的实现方式是从数列的末尾开始遍历,使用一个集合 `seen` 来存储已经遍历过的数字,如果当前数字已经在集合中出现过,则更新 `last_duplicate` 的值为当前下标。如果当前数字是第一次出现,则将其添加到集合 `seen` 中。最后返回 `last_duplicate` 的值即可。