java现有两个递增有序的数组A和B,将两个数组合并为数组C且递增排列。 数组A:1,7,9,11,13,15,17,19 数组B:2,4,6,8,10 合并后数组C:1,2,4,6,7,8,9,10,11,13,15,17,19
时间: 2023-09-13 19:03:51 浏览: 74
同样可以使用双指针法来合并两个有序数组。Java代码实现如下:
```java
public static int[] merge(int[] nums1, int[] nums2) {
int i = 0, j = 0, k = 0;
int[] merged = new int[nums1.length + nums2.length];
while (i < nums1.length && j < nums2.length) {
if (nums1[i] < nums2[j]) {
merged[k++] = nums1[i++];
} else {
merged[k++] = nums2[j++];
}
}
while (i < nums1.length) {
merged[k++] = nums1[i++];
}
while (j < nums2.length) {
merged[k++] = nums2[j++];
}
return merged;
}
```
上面的代码中,我们使用了三个指针,`i`和`j`分别指向两个数组的起始位置,`k`指向合并后数组的起始位置。我们比较`nums1[i]`和`nums2[j]`的大小,将较小的数添加到`merged`数组中,并将对应指针向后移动一位。重复该过程直到有一个数组的所有元素都加入到`merged`数组中,最后将剩余元素直接加入到`merged`数组中即可。
阅读全文