快速排序随机选择基数

在快速排序中 对于乱序的数组 选择基准数方式对算法时间复杂度差不多
但是对于一些已经是有序的数组,基准数的选择的不同,时间效率大大不同。所以引入了随机选取基准值方法和三数取中法,选取基准值。

快速排序选择基数有基本分为三种方法:
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];
	*/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值