快速排序的基本思想:通过一趟排序将待排记录分隔成独立的两部分,其中一部分记录的关键字均比另一部分的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序。
算法描述
快速排序使用分治法来把一个串(list)分为两个子串(sub-lists)。具体算法描述如下:
1.从数列中挑出一个元素,称为 “基准”(pivot);
2.重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分区退出之后,该基准就处于数列的中间位置。这个称为分区(partition)操作;
3.递归地(recursive)把小于基准值元素的子数列和大于基准值元素的子数列排序。
代码:
/// <summary>
/// 快速排序方法
/// </summary>
/// <param name="arr">进行排序的数组</param>
/// <param name="first">分治出的一段的开始的下标</param>
/// <param name="last">分治出的一段的结束的下标</param>
static void Sort(int[] arr, int first, int last)
{
if (first < last)
{
int i = first;
int j = last;
int x = arr[i];
while (i < j)
{
while (i < j)
{
if (x > arr[j])
{
arr[i] = arr[j];
break;
}
else
{
j--;
}
}
while (i < j)
{
if (x < arr[i])
{
arr[j] = arr[i];
break;
}
else
{
i++;
}
}
}
arr[i] = x;
Sort(arr, first, i - 1);
Sort(arr, i + 1, last);
}
}