首页 > 代码库 > 蓝桥杯ALGO-1,区间k大数查询
蓝桥杯ALGO-1,区间k大数查询
#include<stdio.h>
int devide(long a[],int low,int high){
long key=a[high];
while(low<high){
while(low<high&&a[low]>key){
low++;
}
if(low<high)
a[high--]=a[low];
while(low<high&&a[high]<key){
high--;
}
if(low<high)
a[low++]=a[high];
}
a[high]=key;
return high;
}
void sort(long a[],int low,int high){
if(low>high){
return ;
}
int j;
j=devide(a,low,high);
sort(a,low,j-1);
sort(a,j+1,high);
}
int main(){
int n,i,j;
long a[1000],b[1000];
int m;
int l,r,k;
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%ld",&a[i]);
}
scanf("%d",&m);
for(i=0;i<m;i++){
for(j=0;j<n;j++){
b[j]=a[j];
}
scanf("%d%d%d",&l,&r,&k);
sort(b,l-1,r-1);
printf("%d\n",b[l+k-2]);
}
return 0;
}
蓝桥杯ALGO-1,区间k大数查询
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。