還有其他的方法,這裡我列出最簡單的方法來實作。
1、Java合并兩個數組
第一種:
public static void main(String[] args) {
int[] a = new int[]{58, 64, 21, 0, 89, 31, 26};
int[] b = new int[]{6, 7, 8};
int[] c = new int[a.length + b.length];
int i;
for (i = 0; i < a.length; i++) {
c[i] = a[i];
}
for (int j = 0; j < b.length; j++) {
c[i + j] = b[j];
}
// 輸出合并後的數組
System.out.println(Arrays.toString(c));
}
輸出結果:
第二種:
public static void main(String[] args) {
// 兩個待合并數組
int array1[] = {20,10,50,40,30};
int array2[] = {1,2,3};
// 動态初始化數組,設定數組的長度是array1和array2長度之和
int array[] = new int[array1.length + array2.length];
// 循環添加數組内容
for (int i = 0; i < array.length; i++) {
if (i < array1.length) {
array[i] = array1[i];
} else {
array[i] = array2[i - array1.length];
}
}
System.out.println("合并後:");
for (int element : array) {
System.out.printf("%d ", element);
}
}
輸出結果:
2、Java數組排序并去重
public static void main(String[] args) {
/*
思路:
1.hashset去重
2.轉成treeset排序
3.轉成integer數組
4.轉成int數組
5.輸出
*/
Integer[] array = {1, 3, 4, 3, 2, 5, 6, 3, 9, 22};
//去重
HashSet<Integer> hashset = new HashSet<>();
for (int i = 0; i < array.length; i++) {
hashset.add(array[i]);
}
//轉成TreeSet排序
TreeSet<Integer> treeSet = new TreeSet<>(hashset);
//轉成integer數組
Integer[] integers = treeSet.toArray(new Integer[]{});
int[] ints = new int[integers.length];
//foreach僅可用于周遊輸出數組,但不能用于修改數組。
for (int i = 0; i < integers.length; i++) {
ints[i] = integers[i].intValue();
}
// 使用JDK1.8新特性輸出
Arrays.stream(ints).forEach(System.out::println);
}
輸出結果: