歸併操做的過程以下:ios
#include<iostream> using namespace std; int data[8]={1,2,3,4,1,9,6,8}; int merge(int unSorted[],int sorted[],int first,int mid,int last){ int fpoint=first; int spoint=mid+1; int sortedPoint=first; while(fpoint<=mid && spoint<=last){ if(unSorted[fpoint]<unSorted[spoint]) sorted[sortedPoint++]=unSorted[fpoint++]; else sorted[sortedPoint++]=unSorted[spoint++]; } if(fpoint>mid) while(sortedPoint<=last) sorted[sortedPoint++]=unSorted[spoint++]; if(spoint>last) while(sortedPoint<=last) sorted[sortedPoint++]=unSorted[fpoint++]; for(int i=first;i<=last;i++) unSorted[i]=sorted[i]; return 0; } int myMergeSort(int unSorted[],int sorted[],int begin,int end){ if(begin<end){ int mid=(begin+end)/2; myMergeSort(unSorted,sorted,begin,mid); myMergeSort(unSorted,sorted,mid+1,end); merge(unSorted,sorted,begin,mid,end); } return 0; } int main(){ int *sortedData=(int *)malloc(sizeof(data)); //merge(data,sortedData,0,3,7); myMergeSort(data,sortedData,0,7); for(int i=0;i<8;i++) cout<<sortedData[i]<<" "; getchar(); return 0; }