java集合操作

package Sets;
import java.util.HashSet;
import java.util.Iterator;
import java.util.Set;
import java.util.TreeSet;

/**
* java集合操作
*
* @author baby69yy2000
*
*/
public class Sets {

/** 求并集 */
public static <T> Set<T> union(Set<T> setA, Set<T> setB) {
Set<T> setUnion;

if (setA instanceof TreeSet)
setUnion = new TreeSet<T>();
else
setUnion = new HashSet<T>();

Iterator<T> iterA = setA.iterator();
while (iterA.hasNext())
setUnion.add(iterA.next());

Iterator<T> iterB = setB.iterator();
while (iterB.hasNext())
setUnion.add(iterB.next());
return setUnion;
}

/** 求交集 */
public static <T> Set<T> intersection(Set<T> setA, Set<T> setB) {
Set<T> setIntersection;
T item;

if (setA instanceof TreeSet)
setIntersection = new TreeSet<T>();
else
setIntersection = new HashSet<T>();

Iterator<T> iterA = setA.iterator();
while (iterA.hasNext()) {
item = iterA.next();
if (setB.contains(item))
setIntersection.add(item);
}
return setIntersection;
}

/** 求差集 */
public static <T> Set<T> difference(Set<T> setA, Set<T> setB) {
Set<T> setDifference;
T item;

if (setA instanceof TreeSet)
setDifference = new TreeSet<T>();
else
setDifference = new HashSet<T>();

Iterator<T> iterA = setA.iterator();
while (iterA.hasNext()) {
item = iterA.next();
if (!setB.contains(item))
setDifference.add(item);
}
return setDifference;
}

/**
* 判断子集操作 判断setA中的每个元素是否也存在于setB中
*/
public static <T> boolean subset(Set<T> setA, Set<T> setB) {
return intersection(setA, setB).size() == setA.size();
}

/********************************下面是有序集的操作********************************/

/** 求交集 */
public static <T extends Comparable<? super T>> TreeSet<T> orderedIntersection(
Set<T> a, Set<T> b) {
TreeSet<T> setIntersection = new TreeSet<T>();
Iterator<T> iterA = a.iterator(),
iterB = b.iterator();
T valueA, valueB;

valueA = advance(iterA);
valueB = advance(iterB);
while(valueA != null && valueB != null) {
if(valueA.compareTo(valueB) < 0)
valueA = advance(iterA);
else if(valueB.compareTo(valueA) < 0)
valueB = advance(iterB);
else {
setIntersection.add(valueA);
valueA = advance(iterA);
valueB = advance(iterB);
}
}
return setIntersection;
}

private static <T> T advance(Iterator<T> iter) {
T value = null;
if (iter.hasNext())
value = iter.next();
return value;
}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值