快速排序的一个小坑

第一版不知为何一直报错,代码如下


int partition(int a[], int low, int high)
{
	int key = a[low];
	while (low < high)
	{
		while (a[high] >= key && low<high) high--;
		a[low] = a[high];
		while (a[low] <= key && low<high) low++;
		a[high] = a[low];
	}
	printf("%d %d", low, high);
	printf("\n");
	a[low] = key;
	return low;

}

void quickSort(int a[], int low, int high)
{
	if (low == high) return;
	int pivot = partition(a, low, high);
	quickSort(a, low, pivot - 1);
	quickSort(a, pivot + 1, high);
}
int main()
{
	//int a[] = { 46,87,123,12,9,55,3 };
	//int a[] = { 1,2,3,4,5,6,7 };
	int a[] = { 7,6,5,4,3,2,1 };
	//insertSort(a, 7);
	// bbleSort(a, 7);
	// lectSort(a, 7);
	//mergeSort(a, 0, 6);
	quickSort(a, 0, 6);

	for (int i = 0; i < 7; i++)
		printf("%d ", a[i]);
	while (1);
	return 0;
}

后来发现,当low==pivot时,下面这句话会有问题:

	quickSort(a, low, pivot - 1);

于是改为:

    if (pivot > low)
		quickSort(a, low, pivot - 1);
    quickSort(a, pivot + 1, high);

仍然不对,最后发现是下面那句也要改:

	if (pivot > low)
		quickSort(a, low, pivot - 1);
	if(pivot<high)
		quickSort(a, pivot + 1, high);

但是书上和网上的标答都没有这么麻烦啊??最后发现:我的递归出口是low=hight,而标答是low>=high,如果这样一改,刚才的两句if也就不需要了:

void quickSort(int a[], int low, int high)
{
	if (low >= high) return;
	int pivot = partition(a, low, high);
	//if (pivot > low)
		quickSort(a, low, pivot - 1);
	//if(pivot<high)
		quickSort(a, pivot + 1, high);
}
posted @ 2018-09-08 17:06  YuQiao0303  阅读(182)  评论(0编辑  收藏  举报