How to Find All Duplicates in an Array using Python?
- 时间:2020-09-07 12:26:38
- 分类:网络文摘
- 阅读:155 次
Given an array of integers, 1 ≤ a[i] ≤ n (n = size of array), some elements appear twice and others appear once.
Find all the elements that appear twice in this array.
Could you do it without extra space and in O(n) runtime?
Example:
Input:
[4,3,2,7,8,2,3,1]Output:
[2,3]
Using Python’s Collections.Counter to Find All Duplicates in Array
Using collections.Counter in Python allows us to count the frequencies of the elements in an array or list in Python. Then, we can use the List comprehensions to create a list of the duplicate elements in an array by checking their frequencies. Finally, we need to convert it to set, this allows us to filter out the duplicates in the duplicates.
1 2 3 4 | class Solution: def findDuplicates(self, nums: List[int]) -> List[int]: c = collections.Counter(nums) return set([x for x in nums if c[x] > 1]) |
class Solution:
def findDuplicates(self, nums: List[int]) -> List[int]:
c = collections.Counter(nums)
return set([x for x in nums if c[x] > 1])This solution requires O(N) time and O(N) space as we are storing the frequencies in a dictionary object.
–EOF (The Ultimate Computing & Technology Blog) —
推荐阅读:春季喝蜂蜜功效胜补品抗过敏润肺止咳 这十种食用方法让蜂蜜营养又健康 婴幼儿等四类人群不宜食用蜂蜜 教你这七招快速辨别蜂蜜的真假 舌尖上的中国之虾子面背后的故事 豆浆和什么食物一起搭配吃更健康 家庭制作豆浆的步骤及豆浆搭配宜忌 怎么喝啤酒健康养生及饮用啤酒禁忌 饮食安全:警惕9类食物含强致癌物质 造成牙龈萎缩的原因及食疗预防牙龈萎缩
- 评论列表
-
- 添加评论