蓝桥杯 算法提高 上帝造题五分钟(线段树)
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
时间限制: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; }
相关文章推荐
- 利用AOP实现基于注解的参数检查
- 远程推送didReceiveRemoteNotification代理方法调用详细说明
- 虚函数问题探讨
- 根据先序、中序、后序中的两者还原二叉树——递归函数和Csharp泛型
- CSS 漸變效果
- Instance one: fetch the version of mysql database
- 搭建自己的AppRTCDemo服务器
- shell脚本实现自动生成文件并更改其权限
- Activity的传值和生命周期
- 【经典算法】:皇帝的遗产
- DIV实现纵向滚动条overflow-y
- html5 bootstrap的名单管理(重构之前)
- 每天学习十分钟9之工作笔记
- 【经典算法】:运动会问题
- body-parser插件的坑
- GitFlow教程
- 如何清除VS2008的最近打开项目
- GTK、KDE、Gnome、XWindows 图形界面
- js中控制时间
- break与continue区别