从我的问题
我已经完成了我的插入方法。
现在我尝试找出如何构建并集、交集和差分方法来对 2 个 IntSet 进行操作。
请注意,IntSet 的元素数量很大,我需要在O(m+n)时间内完成,其中 m 和 n 是两个 IntSet 的元素数量。
例如 IntSet
a = new IntSetExtra();
b = new IntSetExtra();
for(int i=0; i<300; i++){ a.insert(2*i); }
for(int i=0; i<300; i++){ a.insert(i); }
for(int i=20000; i<50000; i++){ b.insert(i); }
我该怎么做?
PS它可以使用归并排序吗?
编辑:
这是我的联合代码
public IntSetExtra union(IntSetExtra a){
//effect: return new IntSet that union between this and a;
IntSetExtra intSet = new IntSetExtra();
intSet.addAll(a);
for(int i=0; i<a.size(); i++){
if(!intSet.contains(a.get(i))){
intSet.insert(a.get(i));
}
}
return intSet;
}