看书、思考、写代码!
/******************************************* * copyright@hustyangju * blog: http://blog.csdn.net/hustyangju * 2014-11-04 * 题目:并归排序 * 描述:中分法递归分解一个区间的数组,再合并子区间,在合并时完成排序 * 解题思路:递归法,利用临界条件层层合并 * 时间复杂度:O(n lgn) * 空间复杂度:O(n) * ******************************************/ #include <iostream> #include <vector> #include <algorithm> using namespace std; class merge_sort { public: merge_sort(int *p,int num):_p(p),_num(num){} ~merge_sort(){} void print(); void sort(int s,int e); protected: void _merge(int s,int m,int e); private: int *_p; int _num; }; void merge_sort::print() { for(int i=0;i<_num;i++) { cout<<_p[i]<<" "; // _p++; } cout<<endl; } void merge_sort::sort(int s,int e) { if(s<e) { int m = int((s+e)/2); sort(s,m); sort(m+1,e); _merge(s,m,e); } } void merge_sort::_merge(int s,int m,int e) { int i=s; vector<int> vec; merge(_p+s,_p+m+1,_p+m+1,_p+e+1,back_inserter(vec));//merge合并的两个区间是前闭后开区间 for(vector<int>::iterator it=vec.begin();it!=vec.end();it++) { *(_p+i)=*it; i++; } } int main() { int array[10]={2,6,66,7,1,88,9,20,11,54}; cout<<"before:"<<endl; for(int i=0;i<10;i++) cout<<array[i]<<" "; cout<<endl; merge_sort mysort(array,10); // mysort.print(); mysort.sort(0,9); cout<<"after:"<<endl; mysort.print(); }
原文地址:http://blog.csdn.net/hustyangju/article/details/40795145