求n个元素序列中第k大的元素

求n个元素序列中第k大的元素

#include<iostream>

using namespace std;

#include<time.h>

#include<stdlib.h>

int m1,m2,k,r[20001];

int s(int m1,int m2,int k)

{

int i,j;

if(m1<m2){

i=m1;

j=m2;

r[0]=r[i];

while(i!=j){

while(r[j]<=r[0]&&j>i)//检查从右至左数是否小于基准

j=j-1;

if(j>i){r[i]=r[j];i=i+1;}//把大于基准的一个值赋给r[i]

while(r[i]>=r[0]&&j>i)

i=i+1;

if(j>i){r[j]=r[i];j=j-1;} //把小于基准的一个值赋给r[j]

}

}

r[i]=r[0];

if(i=k) return r[k];

else if(i<k) return s(i+1,m2,k);

else return s(m1,i-1,k);

}

void main(){

int i,n,t;

int s(int m1,int m2,int k);

t=time(0)%1000;srand(t);

cout<<"参与选择的有n个整数,请确定n:"<<endl;

cin>>n;

cout<<"选择第k大整数,请确定k:"<<endl;

cin>>k;

cout<<"参与选择的"<<n<<"个整数为"<<endl;

for(i=1;i<=n;i++)

{

r[i]=rand()%(4*n)+10;

cout<<r[i]<<endl;

}

 

s(1,n,k);

cout<<"以上"<<n<<"个整数中第"<<k<<"大的整数为"<<r[k]<<endl;

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

疯子佳人傻了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值