合并两个排序的数组

#include
using namespace std;

/*有两个排序的数组A1和A2,内存在A1的末尾有足够多的空余空间容纳A2.
实现一个函数,把A2中的所有数字插入到A!中并且所有的数字是排序的。*/


/*思路:先计算出两个数组中元素的总个数,然后从尾到头比较array1和array2中的数字,
        并把较大的数字复制到array1的合适位置。*/

//num1和num2分别表示array1和array2中数字的个数,  length表示array1的长度。
void Merge(int array1[], int array2[], int length, int num1, int num2)
{
	int num = num1 + num2;
	if(num > length)
		return;

	if(array1 == NULL || array2 == NULL || length < 0)
		return;

	int i = num1 - 1;
	int j = num2 - 1;
	int k = num - 1;
    while(i >= 0 && j >= 0)
	{
		if(array1[i] > array2[j])
			{
				array1[k--] = array1[i--];
		    }
		else
			array1[k--] = array2[j--];

	}
	if(i >= 0)
	{
		while(i >= 0)
			array1[k--] = array1[i--];
    }
		
	if(j >= 0)
	{
		while(j >= 0)
			array1[k--] = array2[j--];
	}
}

/*判断两个数组是否相等*/
bool isSame(int a[], int b[], int sum1, int sum2)
{
	if(sum1 != sum2)
		return false;
	if(a == NULL || b == NULL)
		return false;
	for(int k = 0; k < sum1; k++)
		if(a[k] != b[k])
			return false;
	return true;

}
/*测试代码*/
void Test(char* testName, int array1[], int array2[], int length, int num1, int num2, int expect[], int k)
{
	if(testName != NULL)
		cout << testName << "begins"<< endl;
	Merge(array1, array2, length, num1, num2);

	/*打印出array1中的元素*/
	cout << "array1:";
	for(int i = 0; i < num1 + num2; i++)
		cout <

输出结果为:

合并两个排序的数组_第1张图片

你可能感兴趣的:(c++)