题目
类型:排序
解题思路
方法一:先把第二个数组放到第一个数组的末尾合并起来,然后排序
方法二:使用双指针将两个数组看作队列,每次从两个数组头部取出比较小的数字放到结果中
方法三:
代码
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;}}}
