java中如何合并两个数组_两个数组合并

java中如何合并两个数组_两个数组合并在 Java 中 合并两个数组可以通过以下几种方法实现 1 使用 System arraycopy 方法 javaint array1 1 2 3 int array2 4 5 6 int mergedArray new int array1 length array2 length System arraycopy array1 0

在Java中,合并两个数组可以通过以下几种方法实现:

1. 使用`System.arraycopy()`方法:

 int[] array1 = {1, 2, 3}; int[] array2 = {4, 5, 6}; int[] mergedArray = new int[array1.length + array2.length]; System.arraycopy(array1, 0, mergedArray, 0, array1.length); System.arraycopy(array2, 0, mergedArray, array1.length, array2.length); 

2. 使用`Arrays.copyOf()`方法:

 int[] array1 = {1, 2, 3}; int[] array2 = {4, 5, 6}; int[] mergedArray = Arrays.copyOf(array1, array1.length + array2.length); System.arraycopy(array2, 0, mergedArray, array1.length, array2.length); 

3. 使用`Arrays.sort()`方法对合并后的数组进行排序:

 int[] array1 = {1, 3, 5}; int[] array2 = {2, 4, 6}; int[] mergedArray = mergeAndSort(array1, array2); System.out.println(Arrays.toString(mergedArray)); public static int[] mergeAndSort(int[] array1, int[] array2) { int[] mergedArray = new int[array1.length + array2.length]; System.arraycopy(array1, 0, mergedArray, 0, array1.length); System.arraycopy(array2, 0, mergedArray, array1.length, array2.length); Arrays.sort(mergedArray); return mergedArray; } 

4. 使用双指针方法合并两个有序数组:

 public static int[] mergeArrays(int[] arr1, int[] arr2) { int[] merged = new int[arr1.length + arr2.length]; int i = 0, j = 0, k = 0; while (i < arr1.length && j < arr2.length) { if (arr1[i] < arr2[j]) { merged[k++] = arr1[i++]; } else { merged[k++] = arr2[j++]; } } while (i < arr1.length) { merged[k++] = arr1[i++]; } while (j < arr2.length) { merged[k++] = arr2[j++]; } return merged; } 

5. 使用`List`类的`addAll()`方法合并数组:

 String[] array1 = {"y", "i", "i"}; String[] array2 = {"b", "a", "i"}; List 
  
    
  
    list = new ArrayList<>(Arrays.asList(array1)); 
   list.addAll(Arrays.asList(array2)); Object[] mergedArray = list.toArray(); System.out.println(Arrays.toString(mergedArray)); 

以上方法都可以用来合并两个数组。选择哪一种方法取决于你的具体需求,例如是否需要排序、数组长度等因素。

编程小号
上一篇 2025-01-18 09:43
下一篇 2025-01-18 09:39

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://sigusoft.com/bj/134658.html