在快速排序中 对于乱序的数组 选择基准数方式对算法时间复杂度差不多
但是对于一些已经是有序的数组,基准数的选择的不同,时间效率大大不同。所以引入了随机选取基准值方法和三数取中法,选取基准值。
快速排序选择基数有基本分为三种方法:
1.端点作为基数
2.随机值基数
3.三数取中法
当选择随机数或者中位数作为基准值时,需要注意的是首先应让变量pivot保存基准值,然后需要将基准值交换到right边界【重点】(为了在交换过程中不被交换到任意一处而换不回来 !!!)
在刷LC某题时: 462. 最少移动次数使数组元素相等 II
需要用到快速排序的思想
下面是一段随机基准数且返回pivot的函数:
int partition(vector<int>&a,int left,int right)
{
srand((unsigned )time(NULL));
int index = left+ rand() %(right-left);
int p = a[index];
sw(a,index,right); //将随机的index和right交换!!
int i = left;
for(int j = left;j<=right;++j)
{
if(a[j]<p)sw(a,i++,j);
}
sw(a,i,right); //将基准数重新回到正确位置!!
return i;
}
补充 下面代码段为三种选择基准数方式
int Partition(int array[], int low, int high){
/*三数中值分割法*/
int m = low + (high - low) / 2;//数组中间元素的下标
if (array[low]>array[high]) //保证左端较小
swap(array, low, high);
if (array[m] > array[high]) //保证中间较小
swap(array, high, m);
if (array[m] > array[low])
swap(array, m, low); //保证左端最小
//此时array[low]已经为整个序列左中右三个关键字的中间值
int pivotkey = array[low];
/*固定基准元
int pivotkey = array[high];
*/
/*随机基准元
int randomIndex = rand() % (high - low) + low;//取数组中随机下标
swap(array, randomIndex, high); //与第一个数交换
int pivotkey = array[high];
*/