求两个数组的并集减去交集的部分,有什么好的算法

 我来答
司马刀剑
高粉答主

2017-10-19 · 每个回答都超有意思的
知道顶级答主
回答量:4.6万
采纳率:93%
帮助的人:7513万
展开全部
首先对较短的一个数组(设长度为a)建立平衡二叉搜索树(需要alog2(a)的时间)。
然后对另一个数组(设长度为b)的每一个元素,在a的搜索树中查找(需要blog2(a)的时间)。
所以总共需要alog2(a)+blog2(a)的时间。
而2楼的算法需要ab的时间。
当b>a>4时,
a>2log2(a)
log2(a)<a-log2(a)
log2(a)/(a-log2(a))<1
alog2(a)/(a-log2(a))<a
又b>a
alog2(a)/(a-log2(a))<b
alog2(a)<ab-blog2(a)
alog2(a)+blog2(a)<ab
所以b>a>4时我的算法比2楼快。
当然,还有常数项的问题,上面的“快”只是渐进意义上的快。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式