超级玛丽
来源:互联网 发布:萨特 存在主义 知乎 编辑:程序博客网 时间:2024/04/28 08:50
注:此题!=游戏设计&&此题!=字符串超级大水题&&此题==主席树
【题目描述】:
玛丽是世界著名的水管工。他的“魁梧”的身材和惊人的跳跃能力,在我们的记忆中想起。现在可怜的公主又陷入了困境,玛丽需要拯救他的情人。我们把城堡的道路作为一条线(长度是n),在每一个整数点上有一个高Hi的砖块。现在的问题是,在道路[ L,R ]区间马里奥可以跳过的砖块有多少,如果他能跳的最大高度是H。
【输入描述】:
第一行一个整数T,测试数据的数量。
对于每个测试数据:
第一行包含两个整数n和m,n是路的长度,m是查询的个数。
下一行包含n个整数,每一块砖的高度,范围是[ 0 - 1,000,000,000 ]
下一个m行,每行包含三个整数L,R,H,如题意。
【输出描述】:
对每组数据输出"Case X: "(X是从1开始的数据组编号)
其次是M行,每行包含一个整数。第i个整数是第i次查询,玛丽可以跳过的砖头数。
【样例输入】:
110 100 5 2 7 5 4 3 8 7 7 2 8 63 5 01 3 11 9 40 1 03 5 55 5 14 6 31 5 75 7 3
【样例输出】:
Case 1:4003120151
【时间限制、数据范围及描述】:
时间:1s 空间:256M
1 <= n <=10^5; 1 <= m <= 10^5
0 <= L <= R < n; 0 <= H <= 1,000,000,000
主席树入门题+两个坑点。。。坑点一:0<=L<=R<n 。。。
坑点二:0<=H<=1,000,000,000
坑了我15+次才AC。。。
附上AC的丧心病狂代码:
#include<iostream>#include<algorithm>#include<cstdio>#include<cstring>#define MAXN 100010using namespace std;int n,m,p,c;int b[MAXN],num[MAXN],root[MAXN];struct node{int l,r,sum;}a[MAXN*20];inline int read(){int date=0,w=1;char c=0;while(c<'0'||c>'9'){if(c=='-')w=-1;c=getchar();}while(c>='0'&&c<='9'){date=date*10+c-'0';c=getchar();}return date*w;}inline void write(int x){ if(x<0){putchar('-');x=-x;} if(x>9)write(x/10); putchar(x%10+'0');}void insert(int x,int i,int &j,int l,int r){int mid=l+r>>1;a[c++]=a[i];j=c-1;a[j].sum++;if(l==r)return;if(x<=mid)insert(x,a[i].l,a[j].l,l,mid);else insert(x,a[i].r,a[j].r,mid+1,r);}int query(int x,int y,int i,int j,int l,int r){if(x>y)return 0;int mid=l+r>>1,t=a[j].sum-a[i].sum,ans=0;if(x<=l&&r<=y)return t;if(x<=mid)ans+=query(x,y,a[i].l,a[j].l,l,mid);if(y>mid)ans+=query(x,y,a[i].r,a[j].r,mid+1,r);return ans;}void work(){int x,y,z,s,l,r;for(int i=1;i<=n;i++){x=lower_bound(num,num+p,b[i])-num;insert(x,root[i-1],root[i],0,p-1);}while(m--){x=read();y=read();z=read();l=0;r=upper_bound(num,num+p,z)-num-1;s=query(l,r,root[x],root[y+1],0,p-1);write(s);putchar('\n');}}void init(){n=read();m=read();c=1;a[0].l=a[0].r=a[0].sum=0;root[0]=0;for(int i=1;i<=n;i++){b[i]=read();num[i-1]=b[i];}sort(num,num+n);p=unique(num,num+n)-num;}int main(){int t=read();for(int cases=1;cases<=t;cases++){printf("Case %d:\n",cases);init();work();}return 0;}
阅读全文
0 0
- 超级玛丽
- 超级玛丽
- 超级玛丽
- 超级玛丽增强版
- 永远的超级玛丽
- 感谢支持超级玛丽
- MLDN的超级玛丽。。。
- 超级玛丽游戏代码
- 超级玛丽 周赛
- XNA超级玛丽
- 《超级玛丽》1
- 《超级玛丽》2
- 《超级玛丽》3
- 超级玛丽 源码解析
- NOI10超级玛丽游戏
- 算法提高 超级玛丽
- 算法提高 超级玛丽
- 算法提高 超级玛丽
- springboot整合redis
- I AM BACK
- [左偏树]BZOJ 2809——[Apio2012]dispatching
- 项目管理--项目开发基本流程
- 计算机网络第一章概述(2)
- 超级玛丽
- 自顶向下,逐步求精 方法简介
- DFS深度优先搜索
- 树莓派web server搭建
- Python split()方法
- 项目管理--项目启动
- 第一篇:nutz初步了解
- 【CCF】201503_2数字排序
- primer c++ 读书笔记 —— 函数返回