有关快速排序qsort的问题
以下是《C程序设计语言》中的一个qsort函数,有几点疑问,请指教。/* qsort: sort v[left]...v[right] into increasing order */
void qsort(int v[], int left, int right)
{
int i, last;
void swap(int v[], int i, int j);
if (left >= right)
return;
swap(v, left, (left + right) / 2);//这句是交换第一项和中间项,其作用是什么?
last = left;
for (i = left + 1; i <= right; i++)
if (v[i] < v[left])
swap(v, ++last, i);//这里每次循环,last和i的值都是相同的,为什么还要进行交换?
swap(v, left, last);
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;
}