归并排序

最后更新于:2022-04-01 15:56:34

~~~ #include <iostream> #include <stdlib.h> using namespace std; template<class T>void mergeSort(T a[],int left,int right); void printArray(int a[],int n){ for(int i=0;i<n;i++){ cout<<a[i]<<"\t"; } } void Merge(int c[],int d[],int l,int m,int r){ int i=1; int j=m+1; int k=1; while((i<=m)&&(j<=r)){ if(c[i]<=c[j]){ d[k++]=c[i++]; }else{ d[k++]=c[j++]; } } if(i>m){ for(int q=j;q<=r;q++){ d[k++]=c[q]; } }else{ for(int q=i;q<=m;q++){ d[k++]=c[q]; } } } void Copy(int a[],int b[],int left,int right){ for (int i = left; i < right; ++i) { a[i]=b[i]; } } void mergeSort(int a[],int left,int right){ if(left<right){ int i=(left+right)/2; int *b=new int[100]; mergeSort(a,left,i); mergeSort(a,i+1,right); Merge(a,b,left,i,right); Copy(a,b,left,right); } } int main(){ int a[10]={10,3,90,22,8,1,20,100,33,106}; cout<<"排序前:\n"; printArray(a,10); mergeSort(a,0,9); cout<<"排序后:\n"; printArray(a,10); } ~~~
';