计算快速排序中的比较次数

时间:2014-10-27 22:58:38

标签: c++ algorithm sorting quicksort

我有一个功课,我需要实施具有三种分区策略的快速排序,并计算每种策略的比较次数。

为简单起见,每当我们对长度为m-1的数组进行递归调用时,系统会要求我们将m添加到计数中。

我的代码总是返回一个负数,而不是整数溢出问题 我使用long long int并且我仍然拥有它,并且比较的数量无法增长那么多,所以我计算的方式有问题。

在调用我的实现后,我使用is_sorted在100000元素数组上测试了代码并且它已经通过了,所以排序是正确的 这是我的代码:

long quick_sort (vector <int>& A, int l , int r){
    static  long count = 0;
    if ( r<= l)
        return 0;

    //partition
    int i = partition(A, l, r);

    //quicksort left
    int amount = ( ((i -1) -l) >= 0 ?
                            ((i-1) -l) :
                                    0);
    count += amount;
    quick_sort (A,l, i-1);

    //quicksort right
    amount = ((r - (i +1)) >= 0 ?
                        (r - (i +1)) :
                                  0);
    count += amount;
    quick_sort (A,i+1, r);

    return count;

}

2 个答案:

答案 0 :(得分:2)

更改测试值以保存正确的表达式:

count += ( (i-1)-l >= 0 ? (i-1)-l : 0 )
quick_sort (A,l, i-1);

count += ( r-(i+1) >= 0 ? ...
quick_sort (A,i+1, r);

答案 1 :(得分:0)

您希望静态变量未被设置为0。使它成为一个全局变量。

另外,为什么在进行递归调用时而不是在进行调用时进行工作?一次而不是两次这样做会容易得多。