quicksortNew;partitionNew

本文详细介绍了快速排序算法的具体实现过程,包括关键的分区函数partitionNew的两种实现方式,并通过递归调用实现数组的排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

void quicksortNew(int n[], int left,int right)
{
int dp;
int step=right-left;
if(step<=0)return;
else if(step==1)
{
	if(n[left]>n[right])
		swap(n[left],n[right]);
	return;
}
else{

     /*
     这就是下面要讲到的函数,按照上面所说的,就是把所有小于53的数放
     到它的左边,大的放在右边,然后返回53在整理过的数组中的位置。
     */
     dp=partitionNew(n,left,right);

     quicksortNew(n,left,dp-1);

     quicksortNew(n,dp+1,right); //这两个就是递归调用,分别整理53左边的数组和右边的数组
}
}


//我们上面提到先定位第一个数,
//然后整理这个数组,把比这个数小的放到它的左边,大的放右边,然后
//返回这中间值的位置,下面这函数就是做这个的。
int partitionNew(int n[],int left,int right)
{
/*
int lo,hi,pivot,t;

pivot=n[left];
lo=left;
hi=right+1;

while(lo+1!=hi) {
     if(n[lo+1]<=pivot)
       lo++;
     else if(n[hi-1]>pivot)
       hi--;
     else {
       //t=n[lo+1];
       //n[++lo]=n[hi-1];
       //n[--hi]=t;
		 swap(n[++lo],n[--hi]);
     }
}

//n[left]=n[lo];
//n[lo]=pivot;
swap(n[left],n[lo]);
return lo;
//*/

//*
int lo;
lo=left;
int hi=right;
int position=left;
//while(lo!=hi+1)//:)
//while(lo<hi)//:(
//while(lo+1!=hi)//:(
while(position<hi)//:)
{
	if(n[lo]<=n[left])
	{
		position=lo;
	  lo++;
	  
	}
	else if(n[hi]>n[left])
	{
	   hi--;
	   
	}
	else
	{
		swap(n[lo],n[hi]);
		position=lo;
	}
}

swap(n[position],n[left]);
return position;


//if(n[lo]<n[left])
//{
//  swap(n[lo],n[left]);
//  return lo;//<=>return hi
//}
//else
//{
//	return left;
//}
//*/
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值