排序算法–合并排序
归并排序算法主要运用递归,通过递归来实现归并其主体思路就是将区间[left,right]不断均分为两段,[left,mid]和[mid+1,right]然后分别递归到只剩一个数字时,进行合并,将其变为有序的子区间,再有所有子区间合并成为更大的子区间,直到全部变为有序的区间为止。
其合并的操作是最为复杂的,也是最难理解的
void merge(int a[],int left1,int right1,int left2,int right2)
{
int i=left1;
int j=left2;
int index=0,b[MAX];
while(i<=right1&&j<=right2)
{
if(a[i]>a[j])
b[index++]=a[j++];
else
b[index++]=a[i++];
}
while(i<=right1) b[index++]=a[i++];
while(j<=right2) b[index++]=a[j++];
for(int i=0;i<index;i++)
a[left1+i]=b[i];
}
作为合并操作,肯定是又两个子区间组成,所以参数有4个数字,分别是两各子区间的左右下标的数值,分别定义两个变量记录子区间的左端点下标,以两个子区间的初始位置开始相互比较,判断出小的就存入零时数组中,两数中大的就留下接着与另一个子区间的下一位比较直到其中一个子区间比完位置,当然最后会有一个子区间没有比较完,所以我们直接把这个区间剩下的放入零时数组就行了,遍历完后,把临时数组替换会原来的数组。
这有一个细节是,替换为原数组,原数组的下标应该是从最开始传入的左区间而不是0,即为left+i
for(int i=0;i<index;i++)
a[left1+i]=b[i];
然后是递归的操作代码
此代码的理解是首先递归到最小的单元,及一个数字,一个数字必然是有序的,一个有序的单元同另一个由于单元比较,排列,在合并成一个有序的子区间
void mergeSort(int a[],int left,int right)
{
if(left<right)
{
int mid=(left+right)/2;
mergeSort(a,left,mid);
mergeSort(a,mid+1,right);
merge(a,left,mid,mid+1,right);
}
}