提一个很弱智的问题

2019-12-06 16:48:13 +08:00
 hua123s
[1,2,3,4...1000000]
[1,2,4,5...89234]

两个数组元素都是 unique 的

怎么比较高效地从一个数组去重另一个数组?

2117 次点击
所在节点    问与答
15 条回复
hua123s
2019-12-06 17:00:42 +08:00
好像不应该叫去重,是从一个数组里面移除另一个数组
Kilerd
2019-12-06 17:21:38 +08:00
第一个转 Set,然后遍历第二个,从第一个里面删掉。是 O(m n) ?
emeab
2019-12-06 17:22:25 +08:00
array_diff()
wish198
2019-12-06 17:24:32 +08:00
值做下标遍历两次?
coderluan
2019-12-06 17:31:58 +08:00
如果数字都是 int,就类似于 leetcode 第一题吧,顺便还能解决排序和去重问题,复杂度 O(m+n)。
1.申请一个 bool 数组,长度是 1000000,用第一个数族初始化,有的话 1,没有的话 0。
2.然后把第二个数组的数字当成下标去查这个 bool 数组,是 1 的话置 0。
3.把最终的 bool 数组生成相应的 int 数组,也就是把步骤 1 反过来执行。
littleylv
2019-12-06 17:32:08 +08:00
是算法题还是实际情况?
实际运用的话,一般语言都有内置的方法吧不用自己写,比如 PHP 的 https://www.php.net/manual/zh/function.array-diff.php
LFUNWF
2019-12-06 18:53:26 +08:00
numpy.setdiffld(x, y)
LFUNWF
2019-12-06 18:55:50 +08:00
@LFUNWF 上面打错了,是 numpy.setdiff1d(x, y)
arvinsilm
2019-12-06 19:02:28 +08:00
两个数组都是有序的? if(a[m] = b[n]) 移除,m++, n++; if(a[m] > b[n]) ,n++; if(a[m] < b[n]) m++。
每个数组遍历一次,遍历过程中比较大小。
hua123s
2019-12-06 19:10:22 +08:00
@Kilerd O(mn)太惨了吧 。。
hua123s
2019-12-06 19:13:43 +08:00
@coderluan
@arvinsilm
其实想想好像挺简单的~~~2333
across
2019-12-06 19:16:07 +08:00
你这个数组不仅是增序的,还是固定区间整数....
逆向检索去重比计数法还快啊
hua123s
2019-12-06 19:23:06 +08:00
@across emmmm,可以伪代码?
superrichman
2019-12-06 19:55:09 +08:00
如果从开发效率上看我会选择 list(set(a) - set(b)) 就用 python 内置功能搞定, 实际开发过程如果不是关键的地方我会选择简单粗暴的方法. 手动狗头
Kilerd
2019-12-07 12:33:11 +08:00
@hua123s #10 手机打字不知道怎么删多了,应该是 O(m+n)

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/626589

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX