【发布时间】:2011-10-17 20:18:53
【问题描述】:
这就是我所拥有的,但它不起作用。不知道为什么...问题可能出在 quick_sort 函数中。
#include <stdio.h>
#include <stdlib.h>
void quick_sort(int * a, int l, int r);
void swap(int * a, int i, int j);
int main(void)
{
#define N 10
int a[N], i;
for (i = 0; i < N; ++i) {
a[i] = rand();
printf("%d\n", a[i]);
}
quick_sort(a, 0, N - 1);
for (i = 0; i < N; ++i)
printf("%d\n", a[i]);
return 0;
#undef N
}
void quick_sort(int * a, int l, int r)
{
int i, j;
if (l < r) {
swap(a, rand() % (r - l + 1), r);
i = l;
for (j = l; j < r; ++j)
if (a[j] < a[r]) {
swap(a, i, j);
++i;
}
swap(a, i, r);
quick_sort(a, l, i - 1);
quick_sort(a, i + 1, r);
}
}
void swap(int * a, int i, int j)
{
int k;
k = a[i];
a[i] = a[j];
a[j] = k;
}
【问题讨论】:
-
在什么情况下不起作用...?
-
请提供您的
dataset、your output和expected output。 -
l是一个可怕的标识符。在许多情况下,大多数单字母标识符都很糟糕,但在任何情况下,l都非常糟糕!考虑重命名变量(low和high;left和right,llim和rlim,...) -
拉兹比,哈里。解决了。不过还是谢谢。下午。是的,一般来说。但这对我的编辑器来说不是问题,这只是一个玩具实现。
-
l只有在你使用可怕的字体时才可怕......