您的位置:首页 > 其它

蓝桥杯 算法提高 上帝造题五分钟(线段树)

2016-01-05 13:21 337 查看
算法提高 上帝造题五分钟

时间限制:1.0s 内存限制:256.0MB

问题描述

  第一分钟,上帝说:要有题。于是就有了L,Y,M,C

  第二分钟,LYC说:要有向量。于是就有了长度为n写满随机整数的向量

  第三分钟,YUHCH说:要有查询。于是就有了Q个查询,查询向量的一段区间内元素的最小值

  第四分钟,MZC说:要有限。于是就有了数据范围

  第五分钟,CS说:要有做题的。说完众神一哄而散,留你来收拾此题

输入格式

  第一行两个正整数n和Q,表示向量长度和查询个数

  接下来一行n个整数,依次对应向量中元素:a[0],a[1],…,a[n-1]

  接下来Q行,每行两个正整数lo,hi,表示查询区间[lo, hi]中的最小值,即min(a[lo],a[lo+1],…,a[hi])。

输出格式

  共Q行,依次对应每个查询的结果,即向量在对应查询区间中的最小值。

样例输入

7 4

1 -1 -4 8 1 2 -7

0 0

1 3

4 5

0 6

样例输出

1

-4

1

-7

样例说明

  第一个查询[0,0]表示求min{a[0]}=min{1}=1

  第二个查询[1,3]表示求min{a[1],a[2],a[3]}=min{-1,-4,8}=-4

  第三个查询[4,5]表示求min{a[4],a[5]}=min{1,2}=1

  第四个查询[0,6]表示查询整个向量,求min{a[0..6]}=min{1,-1,-4,8,1,2,-7}=-7

数据规模和约定

  1<=n<=1984,1<=Q<=1988,向量中随机整数的绝对值不超过1,000

#include <iostream>
#include <cstdio>
using namespace std;
const int N=2000;
struct Node{
int l,r,v;
}node[N*4];
void InitTree(int now,int l,int r){
if(l==r){
cin>>node[now].v;
node[now].l=l;
node[now].r=l;
return;
}
int mid=(l+r)/2;
int ne=now<<1;
InitTree(ne,l,mid);
InitTree(ne+1,mid+1,r);
node[now].l=l;
node[now].r=r;
node[now].v=min(node[ne].v,node[ne+1].v);
}
int find(int now,int l,int r){
if(node[now].l==l&&node[now].r==r)
return node[now].v;
int mid=(node[now].l+node[now].r)/2;
int ne=now<<1;
if(mid>=r){
return find(ne,l,r);
}
else if(mid<l){
return find(ne+1,l,r);
}
else{
return min(find(ne,l,mid),find(ne+1,mid+1,r));
}
}
int main()
{
int n,q,l,r;
while(cin>>n>>q){
InitTree(1,1,n);
for(int i=0;i<q;i++){
cin>>l>>r;
cout<<find(1,l+1,r+1)<<endl;
}

}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: