1. 程式人生 > >一,比較兩個陣列中不同元素

一,比較兩個陣列中不同元素

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;
}

輸出為: