将合并结果放入第一个数组中
1.双指针法
/**
* 有序数组合并,双指针法
* @param nums1
* @param m
* @param nums2
* @param n
*/
public void merge(int[] nums1, int m, int[] nums2, int n) {
int[] sorted = new int[m + n];
int p1 = 0,p2=0;
int cur;
while (p1 < m || p2 < n){
if (p1 == m){
cur = nums2[p2++];
}else if (p2 == n){
cur = nums1[p1++];
}else if (nums1[p1] < nums2[p2]){
cur = nums1[p1++];
}else{
cur = nums2[p2++];
}
sorted[p1 + p2 -1] = cur;
}
for (int i =0;i< sorted.length;i++){
nums1[i] = sorted[i];
}
}
2.逆向双指针法
/**
* 逆向双指针
* @param nums1
* @param m
* @param nums2
* @param n
*/
public void merge2(int[] nums1, int m, int[] nums2, int n) {
int p1 = m -1;
int p2 = n - 1;
int cur;
int tail = m + n - 1;
while (p1 >=0 || p2 >=0){
if (p1 == -1){
cur = nums2[p2--];
}else if (p2 == -1){
cur = nums1[p1--];
}else if (nums1[p1]<nums2[p2]){
cur = nums2[p2--];
}else{
cur = nums1[p1--];
}
nums1[tail--] = cur;
}
}