|
20鱼币
看了小甲鱼的快速排序算法,有一部分不懂,就是如视频后留的问题:
#include <stdio.h>
void swap(int k[], int low, int high)
{
int temp;
temp = k[low];
k[low] = k[high];
k[high] = temp;
}
int Partition(int k[], int low, int high)
{
int point;
point = k[low];
while( low < high )
{
while( low < high && k[high] >= point )//这里为何是>=,>号完全可以啦,不懂求解释
high--;
}
swap(k, low, high);
while( low < high && k[low] <= point )//这里为何是<=,<号完全可以啦,不懂求解释
{
low++;
}
swap(k, low, high);
}
return low;
}
void QSort(int k[], int low, int high)
{
int point;
if( low < high )
{
point = Partition(k, low, high);
QSort(k, low, point-1);
QSort(k, point+1, high);
}
}
void QuickSort(int k[], int n)
{
QSort(k, 0, n-1);
}
int main()
{
int i, a[10] = {4, 2, 5, 0, 3, 9, 1, 7, 6, 8};
QuickSort(a, 10);
printf("排序后的结果是:");
for( i=0; i < 10; i++ )
{
printf("%d", a[i]);
}
printf("\n\n");
return 0;
} |
|