我有一个功课,我需要实施具有三种分区策略的快速排序,并计算每种策略的比较次数。
为简单起见,每当我们对长度为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;
}
答案 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。使它成为一个全局变量。
另外,为什么在进行递归调用时而不是在进行调用时进行工作?一次而不是两次这样做会容易得多。