一,比較兩個陣列中不同元素
阿新 • • 發佈:2018-12-21
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;
}
輸出為: