查找顺序表中第n/4小的元素

查找第n/4小的元素

本题源于苏州大学872考研2014年真题:设整型元素组成的顺序线性表长度为n,设计一个尽可能高效的算法找出表中第n/4小的数据。

这种题乍一看觉得没有思路,很容易想到一种解题思路:排序后依次向后数n/4个节点即为所找节点,但是这种思路需要考虑到顺序表中出现重复元素的情况,讨论起来非常麻烦(因为我一开始就是这么想的….),以后遇到这种找大小的题,要充分利用当前已有的查找方法的特点和优点,结合题目来做题,毕竟出题也不能出一个你没见过的想都想不出来的算法吧…我觉得应该都是基本算法的改写,举一反三。

算法思想:借用快速排序算法的特点,每进行一次排序,就会有将枢纽节点放到其最终所在位置,如:此时该节点所在位置为A[pivotloc],则该元素为该顺序表中第n小的元素(从小到大排序),且这个元素之前的元素均小于该元素,后面的元素均大于该元素。利用快排的这种特性,则进行一次排序后就能找到第n小的元素,若此时pivotloc>n/4,则表示所查找节点元素值大于当前节点(在它后面),若pivotloc<n/4,则表示小于当前节点(在它前面)。递归调用所在范围的顺序表即可。

下面放上代码:

int find_k_quickSort(int A[],int left,int right,int n){
	if(left<right&&n>=4){//题目条件
		int pivotloc;//枢纽元素最终所在位置,即第几小的元素
		int key = A[left];//枢纽元素
		int low = left;
		int high = right;
		int k = n/4;//找出第k小元素
		while(low<high){//快排
			while(low<high&&A[high]>key) high--;
			A[low] = A[high];
			while(low<high&&A[low]<key) low++;
			A[high] = A[low];
		}//while
		A[low] = key;
		pivotloc = low;//当前枢纽元素的位置
		if(pivotloc==(k-1))//满足条件则找到第k小的元素
			return A[oivotloc];
		else if(pivotloc<(k-1))//在所得元素之后找该元素
			return find_k_quickSort(A,pivotloc,right,k)
		else//在所得元素之前找该元素
			return find_k_quickSort(A,left,pivotloc-1,k)
	}
	else return -1;//数组元素个数小于4
}
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值