剑指Offer上的快速排序的Partition函数与我在数据结构书上学到的不一样,因此就想要探索下这两种不同的处理方式。
1.基本思想
快速排序的基本思想是基于分治法。在待排序表L[1…n]中任取一个元素pivot作为基准,通过一趟排序将待排序表划分为独立的两部分L[1…k-1]和L[k+1…n],使得L[1…k-1]中所有元素小于pivot,L[k+1…n]中所有元素大于或等于pivot,则pivot放在了其最终位置L(k)上。而后递归地对两个子表重复上述过程,直至每部分内只有一个元素或空为止,即所有元素放在了其最终位置上。
2.剑指Offer上的Partition实现
// Partition为分割函数, length表示data数组的长度
int Partition(int data[], int length, int low, int high) {
if (data == nullptr || length <= 0 || low < 0 || high >= length) {
return 1;
}
// 在[low, high]区间中随机取一个基准值,并将其换到区间最末尾
int index = RandomInRange(low, high);
Swap(&data[index], &data[high]);
// small在low的前面一位
int small = low - 1;
for (index = low; index < high; ++index) {
if (data[index] < data[high]) {
// ++small后表示大于基准值的第一个数的下标
// 如果不存在大于基准值的数,则表示当前比较的数字下标
++small;
// 交换后的small表示小于基准值的最后一个数字的下标
if (small != index) {
Swap(&data[index], &data[small