BZOJ2223 [Coci 2009]PATULJCI 题解&代码
来源:互联网 发布:2015淘宝销量排名 编辑:程序博客网 时间:2024/06/06 19:11
题意:给出一个长度为n的序列a满足1≤a[i]≤n。
又有m组询问,每次对于一个区间[l,r]问是否存在一个数在[l,r]中出现的次数大于(r-l+1)/2。如果存在,输出yes,否则输出no。
题解:标准主席树…主席树还是这么简单粗暴QwQ但是我MLE了好多次,这空间卡得我怀疑人生…不过最后的错误反而不在空间233333
我把n和m弄错了WA了好几次,总之是简单错误啦
和BZOJ3524是一道题,链接:
http://blog.csdn.net/rainbow6174/article/details/51074109
/************************************************************** Problem: 2223 User: Rainbow6174 Language: C++ Result: Accepted Time:1072 ms Memory:120412 kb****************************************************************/#include<iostream>#include<cstdio>#include<cstring>using namespace std;const int maxn = 500005;const int maxm = 10005;int n,m,q,l,r,x,cnt,ans,rt[maxn],son[2][maxn*20],sum[maxn*20];void Insert(int rl,int rn,int l,int r,int v){ sum[rn]=sum[rl]+1; if(l==r)return; int mid = (l+r)/2; if(mid>=v) son[1][rn]=son[1][rl],son[0][rn]=++cnt,Insert(son[0][rl],son[0][rn],l,mid,v); else son[0][rn]=son[0][rl],son[1][rn]=++cnt,Insert(son[1][rl],son[1][rn],mid+1,r,v); //cout<<rl<<' '<<rn<<' '<<sum[son[0][rn]]<<' '<<sum[son[0][rl]]<<' '<<v<<endl;}int query(int rl,int rn,int l,int r,int k){ if(l==r)return l; int mid = (l+r)/2; if(sum[son[0][rn]]-sum[son[0][rl]]>k) return query(son[0][rl],son[0][rn],l,mid,k); if(sum[son[1][rn]]-sum[son[1][rl]]>k) return query(son[1][rl],son[1][rn],mid+1,r,k); return 0;}int main(void){ //freopen("patuljci10.in","r",stdin); //freopen("patuljci.ans","w",stdout); scanf("%d%d",&n,&m); for(int i = 1; i <= n; i++)rt[i]=++cnt; for(int i = 1; i <= n; i++) { scanf("%d",&x); Insert(rt[i-1],rt[i],1,m,x); } scanf("%d",&q); for(int i = 1; i <= q; i++) { scanf("%d%d",&l,&r); ans=query(rt[l-1],rt[r],1,m,(r-l+1)/2); if(ans)printf("yes %d\n",ans); else printf("no\n"); } return 0;}
0 0
- BZOJ2223 [Coci 2009]PATULJCI 题解&代码
- [BZOJ2223][Coci 2009]PATULJCI
- bzoj2223[Coci 2009] PATULJCI
- bzoj2223 [Coci 2009]PATULJCI
- bzoj2223: [Coci 2009]PATULJCI 主席树
- BZOJ2223: [Coci 2009]PATULJCI&&BZOJ3524: [Poi2014]Couriers
- [BZOJ3524] [Poi2014]Couriers/[BZOJ2223] [Coci 2009]PATULJCI
- BZOJ3524: [Poi2014]Couriers/BZOJ2223: [Coci 2009]PATULJCI
- [bzoj2223][Coci 2009]PATULJCI 主席树
- bzoj2223 [Coci 2009]PATULJCI(同bzoj3524)
- [BZOJ2223][Coci 2009]PATULJCI(整体二分+bit)
- [BZOJ2223][[Coci 2009]PATULJCI][主席树+特判]
- 【BZOJ】【P2223】【Coci 2009】【PATULJCI】【题解】【整体二分】
- bzoj 2223: [Coci 2009]PATULJCI
- BZOJ 2223: [Coci 2009]PATULJCI
- BZOJ 2223: [Coci 2009]PATULJCI
- BZOJ2223 PATULJCI COCI2009_CONTSET3
- [分块 随机化] BZOJ 2223 [Coci 2009]PATULJCI
- jquery跑马灯抽奖
- hadoop2.6.0伪分布式+spark1.6.0配置记录
- 1st 6月1日
- 序列化和反序列化
- iOS开发之旅--ReactiveCocoa使用小结2
- BZOJ2223 [Coci 2009]PATULJCI 题解&代码
- 使用bash工具创建 ssh key
- 通过Spring Resource接口获取资源
- 简易百度地图定位地址
- Windows下使用EasyBCD安装Linux双系统实践
- TCP协议和UDP协议的区别
- JavaSE基础之查找质数
- 初试编程+算法
- Spring 之IOC容器(初级)