4、快速排序
快速排序的基本思想是分治,从序列中随机选取一个数,把整个序列中所有比这个数小的放到左半边,把比这个数大的放到右半边,然后再递归的排左半边和右半边。
模版如下,我还没有看懂。。
1 void quick_sort(vector<int> &q, int l, int r){ 2 if(l >= r) return; 3 int i = l - 1, j = r + 1, x = q[l + r >> 1]; 4 while(i < j){ 5 do j--; while(q[j] > x); 6 do i++; while(q[i] < x); 7 if(i < j) swap(q[i], q[j]); 8 else quick_sort(q, l, j), quick_sort(q, j+1, r); 9 } 10 }
5、归并排序
归并排序也是分治的思想,把序列分成等长的两半,先把左半边递归的排好序,再把右半边递归的排好序,这样得到了两个有序的序列,再把它们合并成一个有序的序列。代码依旧是没有看懂。。。
1 void merge_sort(vector<int> &q, int l, int r){ 2 if(l >= r) return; 3 int mid = (l + r) / 2; 4 merge_sort(q, l, mid); 5 merge_sort(q, mid + 1, r); 6 7 static vector<int> w; 8 w.clear(); 9 10 int i = l, j = mid + 1; 11 while(i <= mid && j <= r){ 12 if(q[i] < q[j]) 13 w.push_back(q[i++]); 14 else 15 w.push_back(q[j++]); 16 } 17 18 while(i <= mid) w.push_back(q[i++]); 19 while(j <= r) w.push_back(q[j++]); 20 for(i = l, j = 0; j < w.size(); i++, j++) q[i] = w[j]; 21 }