标题:C++ 实现快速排序问题?
取消只看楼主
hcs_xiaohan
Rank: 2
等 级:论坛游民
帖 子:40
专家分:23
注 册:2016-7-4
结帖率:91.67%
已结贴  问题点数:20 回复次数:0 
C++ 实现快速排序问题?
程序目的如题,代码如下:
#include <iostream>
#include <cstdlib>
#include <algorithm>

using namespace std;

template <typename T>
void quicksort(T B[], int lo, int hi);
template <typename T>
int Partition(T B[], int lo, int hi);

int main() {

    int a[] = {6,5,0,1,34,9,4,4,4,2,-1};
    for(int i = 0; i < 11; i++)
        cout << a[i] << ",";
    cout << endl;

    quicksort(a, 0, 11);
   
    for(int i = 0; i < 11; i++)
        cout << a[i] << ",";
    cout << endl;

    return 0;
}

template <typename T>
void quicksort(T B[], int lo, int hi) {
    if(hi - lo < 2) return;
   
    int mi = Partition(B, lo, hi - 1);

    quicksort(B, lo, mi);
    quicksort(B, mi+1, hi);
}

template <typename T>
int Partition(T B[], int lo, int hi) {
    swap(B[lo], B[rand()%(hi - lo)]);
    T pivot = B[lo];

    while(lo < hi) {
        while(pivot <= B[hi])
            hi--;
        B[lo] = B[hi];

        while(B[lo] <= pivot)
            lo++;
        B[hi] = B[lo];
    }

    B[lo] = pivot;

    return lo;
}

运行结果如下:

6,5,0,1,34,9,4,4,4,2,-1,
1,0,2,4,-1,5,-309542368,20689408,9,34,-309542080,
*** stack smashing detected ***: ./test terminated
Aborted (core dumped)

请各位看看是哪儿错了?
搜索更多相关主题的帖子: include 
2016-12-06 21:56



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-472059-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.320279 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved