Given two sorted integer arrays A and B, merge B into A as one sorted array.
Note:
You may assume that A has enough space (size that is greater or equal to m + n) to hold additional elements from B. The number of elements initialized in A and B are m and n respectively.
思路:该题较easy,归并排序中的合并步骤。
代码:
void merge(int A[], int m, int B[], int n) {
int indexOfInsert=m+n-1;
int indexOfA=m-1;
int indexOfB=n-1;
while(indexOfA>=0 && indexOfB>=0)
{
if(A[indexOfA]>=B[indexOfB])
{
A[indexOfInsert--]=A[indexOfA--];
}
else
{
A[indexOfInsert--]=B[indexOfB--];
}
}
if(indexOfB>=0)
{
while(indexOfB>=0)
{
A[indexOfInsert--]=B[indexOfB--];
}
}
}
本文介绍了一种将两个已排序的整数数组A和B合并为一个排序数组的方法。此过程遵循归并排序中的合并步骤,从两个数组的末尾开始比较,并将较大的元素放置在数组A预留的空间中,直至所有元素被放置。
333

被折叠的 条评论
为什么被折叠?



