int Cmp(int* a, int* b)
{
return *a - *b;
}
void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n)
{
int p1 = m;
int p2 = 0;
//n为0,说明不插入元素,nums1里面也没多余的位置,直接返回就可以了
if (n == 0)
{
return;
}
while (n)
{
nums1[p1++] = nums2[p2++];
n--;
}
qsort(nums1, nums1Size, sizeof(int), Cmp);
}
void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n)
{
int len = m + n;
int p1 = 0;
int p2 = 0;
int ps = 0;
int sorted[m + n];
if (n == 0)
{
return;
}
// 有len个元素需要被排序,所以一定循环len次
while (len--)
{
//当两个数组下标都越界的时候,循环还没结束,就把另个数组的元素放到sorted数组里
if (p1 == m)
{
sorted[ps++] = nums2[p2++];
}
else if (p2 == n)
{
sorted[ps++] = nums1[p1++];
}
else if (nums1[p1] < nums2[p2])
{
sorted[ps++] = nums1[p1++];
}
else
{
sorted[ps++] = nums2[p2++];
}
}
//把sorted数组里的元素再粘贴到nums1里
for (int i = 0; i < m + n; i++)
{
nums1[i] = sorted[i];
}
}
void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n)
{
int p1 = m - 1; //数组1最后一个有效元素的下标
int p2 = n - 1; //数组2最后一个有效元素的下标
int p = m + n - 1; //数组1最后一个元素的下标
//这个条件保证两数组不会越界,但有可能数组1里面没有有效元素了,而数组2里面还有
while (p1 >= 0 && p2 >= 0)
{
if (nums1[p1] > nums2[p2])
{
nums1[p--] = nums1[p1--];
}
else
{
nums1[p--] = nums2[p2--];
}
}
//把数组2里面的元素依次放进去
while (p2 >= 0)
{
nums1[p--] = nums2[p2--];
}
}