超级玛丽

来源:互联网 发布:萨特 存在主义 知乎 编辑:程序博客网 时间: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;}

原创粉丝点击