题目
类型:排序
解题思路
方法一:先把第二个数组放到第一个数组的末尾合并起来,然后排序
方法二:使用双指针将两个数组看作队列,每次从两个数组头部取出比较小的数字放到结果中
方法三:
代码
class Solution {
public void merge(int[] nums1, int m, int[] nums2, int n) {
int p1 = m - 1, p2 = n - 1;
int tail = m + n - 1;
int cur;
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 = nums1[p1--];
} else {
cur = nums2[p2--];
}
nums1[tail--] = cur;
}
}
}