1,两个数组,找出其中一个比另一个多的元素,例如输入{"1","2","3"} 和{"1","4","5"},结果为{"2","3"}
private Set<String>findScope(String [] oldArray, String [] newArray){
Set<String> noSame = new HashSet<String>();
Set<String> temp = new HashSet<String>();
if(oldArray[0]!=null){
for(int i=0;i<newArray.length;i++){
temp.add(newArray[i]);
}
for(int j=0;j<oldArray.length;j++){
//如果temp中已存在相同的元素,则temp.add(oldArray)返回false
if(temp.add(oldArray[j])){
noSame.add(oldArray[j]);
}
}
}
return noSame;
}
}
public static void main(String[] args) {
String [] oldArray={"1","2","3"};
String [] newArray={"1","4","5"};
Set<String> s=findScope(oldArray,newArray);
System.out.println("s中的元素为----------"+s);
}
结果为:
2,找出两个数组相同元素
//找出两个数组中相同的元素
public static Set<Integer> getIds(Integer[] a, Integer[] b){
Set<Integer> same = new HashSet<Integer>(); //用来存放两个数组中相同的元素
Set<Integer> temp = new HashSet<Integer>(); //用来存放数组a中的元素
for (int i = 0; i < a.length; i++) {
temp.add(a[i]); //把数组a中的元素放到Set中,可以去除重复的元素
}
for (int j = 0; j < b.length; j++) {
//把数组b中的元素添加到temp中
//如果temp中已存在相同的元素,则temp.add(b[j])返回false
if(!temp.add(b[j]))
same.add(b[j]);
}
return same;
}
public static void main(String[] args) {
Integer[] array1 = {1,2,3,4,1,2,4,6,7,8,10,22,33};
Integer[] array2 = {1,2,3,4,1,2,4,6,7,8,10,22,33,55,66,77,88,99};
Set<Integer> sameElementSet = getIds(array1,array2);
System.out.println("sameElementSet中的元素为----------"+sameElementSet);
}
输出结果为:
3,找出两个数组不同元素
public static void main(String[] args) {
Integer[] array1 = {1, 2, 3,5,6};
Integer[] array2 = {1, 2, 3, 4,44};
List<Integer> list = compare(array1,array2);
List<Integer> list1=compare(array2,array1);
list1.addAll(list);
System.out.println("两个数组中的不相同的元素为----------"+list1);
}
//找出两个数组中不相同的元素
public static <T> List<T> compare(T[] t1, T[] t2) {
List<T> list1 = Arrays.asList(t1); //将t1数组转成list数组
List<T> list2 = new ArrayList<T>();//用来存放2个数组中不相同的元素
for (T t : t2) {
if (!list1.contains(t)) {
list2.add(t);
}
}
return list2;
}
输出为: