为什么我的快速排序不起作用

时间:2013-10-13 20:54:38

标签: c++ sorting

我无法弄清楚为什么这段代码不太正确。它对大部分数组进行了排序,但有些数字不合适。任何帮助将不胜感激。

int partition(int* an_array, int from, int to)
{
    int pivot = an_array[(from + to) / 2];
    int left = from;   
    int right = to;   
    while(left < right)
    {
        while(an_array[left] < pivot)
        {
            left = left + 1; 
        }//end while loop       
        while(an_array[right] > pivot)
        {
            right = right - 1; 
        }//end while
        if(left < right)
        {
            swap_numbers(an_array[left], an_array[right]);
            left = left + 1; 
            right = right - 1; 
        }//end if 
    }//end while loop
    return right; 
}//end partition function 


void quick_sort(int* an_array, int from, int to)
{
    if(from >= to) return; 
    int p = partition(an_array, from, to); 
    quick_sort(an_array, from, p); 
    quick_sort(an_array, p + 1, to); 
}//end quick_sort

1 个答案:

答案 0 :(得分:0)

你忘记添加:

swap_numbers(an_array[from], an_array[right]);

之前

return right;
相关问题