首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >查找副本的第三种方法

查找副本的第三种方法
EN

Stack Overflow用户
提问于 2011-05-10 17:16:40
回答 3查看 987关注 0票数 6

检测数组中重复项的两种常见方法:

1)优先排序,时间复杂度为O (n log n),空间复杂度为O (1)

2)哈希集,时间复杂度O (n),空间复杂度O (n)

有没有第三种方法来检测重复的东西?

请不要回答暴力问题。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-05-10 22:31:47

另一种选择是Bloom filter。复杂性O(n),空间变化(几乎总是小于一个散列),但存在误报的可能性。数据集的大小、过滤器的大小和您可以预期的误报数量之间存在复杂的关系。

Bloom过滤器通常被用作在进行更昂贵的重复检查之前的快速“健全检查”。

票数 5
EN

Stack Overflow用户

发布于 2011-05-10 17:31:40

要看信息了。

如果你知道数字的范围,比如1-1000,你可以使用位数组。

假设范围是a...b

用(b-a)位组成一个位数组。将它们初始化为0。

循环数组,当你得到数字x时,将x-a位置的位改为1。

如果那里已经有一个1,那么你就有一个副本。

时间复杂度:O(n)

空间复杂度:(b-a)位

票数 4
EN

Stack Overflow用户

发布于 2011-05-10 20:51:07

如果n个元素数组包含从0到n-1的元素,则另一种查找重复的方法。<Find Duplicates>

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5947856

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档