有人可以解释这种排序算法的作用吗?我无法遵循逻辑,它使用递归。取中间词并将其与第一行(从顶部开始的第 8 行)交换似乎很奇怪。此外,在第一次迭代中,++last = i
, 所以对 swap 的调用被浪费了。
代码设置last = left
, i = left + 1
,然后调用 swap() ++last
。这使得last
平等i
!
/* qsort: sort v[left]...v[right] into increasing order */
void qsort(int v[], int left, int right)
{
int i, last;
if (left >= right) /* do nothing if array contains */
return; /* fewer than two elements */
swap(v, left, (left + right)/2); /* move partition elem */
last = left; /* to v[0] */
for (i = left + 1; i <= right; i++) /* partition */
if (v[i] < v[left])
swap(v, ++last, i);
swap(v, left, last); /* restore partition elem */
qsort(v, left, last-1);
qsort(v, last+1, right);
}
/* swap: interchange v[i] and v[j] */
void swap(int v[], int i, int j)
{
int temp;
temp = v[i];
v[i] = v[j];
v[j] = temp;
}