bzoj-3524 Couriers
题意:
给出一个长度为n的序列和m次询问。
每次询问给出区间[l,r],求区间中出现次数大于(r-l+1)/2的数字。
n。m<=500000。1<=每一个数字<=n;
题解:
主席树的算是裸题吧,静态序列不用套树状数组,数据范围也省了离散化;
直接上主席树就能够了,复杂度就是O((n+m)logn)的样子;
空间略爆炸。可是假设取消Build()函数就能够过了。
orz icebound神犇,搞了一种奇妙的建树法:
- void Insert(int l,int r,int &now,int val)
- {
- a[++cnt]=a[now];
- now=cnt,a[now].sum++;
- if(l==r) return ;
- int mid=l+r>>1;
- if(val<=mid) Insert(l,mid,a[now].l,val);
- else Insert(mid+1,r,a[now].r,val);
- }
这个姿势是不须要提前建空树的,省了2*n的空间;
比較巧妙的就是传地址之后复制结点。再把地址赋值,使新版本号的树独立出来;
所以仅仅须要四个參数就能够了,编程复杂度也非常低;
(我似乎讲的不太明确,yy一下代码就好了)
然后查询啥的搞搞推断也是logn级别,时间上不怎么卡就过了;
bzoj-2223同题。然而不仅数据范围小内存还大了一倍= =;
代码:
- #include<stdio.h>
- #include<string.h>
- #include<algorithm>
- #define N 510000
- using namespace std;
- struct node
- {
- int l,r,sum;
- }a[N*20];
- int root[N],cnt;
- void Build(int l,int r,int &no)
- {
- if(!no) no=++cnt;
- if(l==r) return ;
- int mid=l+r>>1;
- Build(l,mid,a[no].l);
- Build(mid+1,r,a[no].r);
- }
- void Insert(int l,int r,int &now,int val)
- {
- a[++cnt]=a[now];
- now=cnt,a[now].sum++;
- if(l==r) return ;
- int mid=l+r>>1;
- if(val<=mid) Insert(l,mid,a[now].l,val);
- else Insert(mid+1,r,a[now].r,val);
- }
- int query(int l,int r,int nol,int nor,int val)
- {
- if(l==r) return l;
- int mid=l+r>>1;
- if(a[a[nor].l].sum-a[a[nol].l].sum>val)
- return query(l,mid,a[nol].l,a[nor].l,val);
- else if(a[a[nor].r].sum-a[a[nol].r].sum>val)
- return query(mid+1,r,a[nol].r,a[nor].r,val);
- else
- return 0;
- }
- int main()
- {
- int n,m,i,j,k,x,l,r;
- scanf("%d%d",&n,&m);
- // Build(1,n,root[0]);
- for(i=1;i<=n;i++)
- {
- scanf("%d",&x);
- root[i]=root[i-1];
- Insert(1,n,root[i],x);
- }
- for(i=1;i<=m;i++)
- {
- scanf("%d%d",&l,&r);
- printf("%d\n",query(1,n,root[l-1],root[r],r-l+1>>1));
- }
- return 0;
- }
bzoj-3524 Couriers的更多相关文章
- BZOJ 3524 Couriers | 主席树
BZOJ 3524 Couriers 题意 求一个区间内出现超过区间长度的一半的数,如果没有则输出0. 题解 我可能太菜了吧--这道题愣是没想出来-- 维护权值主席树,记录每个数都出现过多少次: 查询 ...
- 洛谷 3567/BZOJ 3524 Couriers
3524: [Poi2014]Couriers Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 2895 Solved: 1189[Submit][S ...
- 主席树||可持久化线段树||BZOJ 3524: [Poi2014]Couriers||BZOJ 2223: [Coci 2009]PATULJCI||Luogu P3567 [POI2014]KUR-Couriers
题目:[POI2014]KUR-Couriers 题解: 要求出现次数大于(R-L+1)/2的数,这样的数最多只有一个.我们对序列做主席树,每个节点记录出现的次数和(sum).(这里忽略版本差值问题) ...
- BZOJ 3524: [Poi2014]Couriers [主席树]
3524: [Poi2014]Couriers Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 1892 Solved: 683[Submit][St ...
- BZOJ 3524: [Poi2014]Couriers
3524: [Poi2014]Couriers Time Limit: 20 Sec Memory Limit: 256 MBSubmit: 1905 Solved: 691[Submit][St ...
- BZOJ 3524 [Poi2014]Couriers(二分+蒙特卡罗)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3524 [题目大意] 给一个长度为n的序列a.1≤a[i]≤n. m组询问,每次询问一个 ...
- BZOJ 3524 [Poi2014]Couriers(可持久化线段树)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3524 [题目大意] 给一个长度为n的序列a.1≤a[i]≤n. m组询问,每次询问一个 ...
- 【BZOJ 3524】【Poi2014】Couriers 可持久化线段树
为什么这个主席树叫可持久化线段树,我不知道,具体得问达神.我无限T,然后DaD3zZ一针见血地指出了我的N*50爆内存导致无限编译超时O)ZO)ZO)Z真是太神啦.以图为鉴: 达神题解传送门:http ...
- 【bzoj 3524】[Poi2014]Couriers
Description 给一个长度为n的序列a.1≤a[i]≤n.m组询问,每次询问一个区间[l,r],是否存在一个数在[l,r]中出现的次数大于(r-l+1)/2.如果存在,输出这个数,否则输出0. ...
- 【刷题】BZOJ 3524 [Poi2014]Couriers
Description 给一个长度为n的序列a.1≤a[i]≤n. m组询问,每次询问一个区间[l,r],是否存在一个数在[l,r]中出现的次数大于(r-l+1)/2.如果存在,输出这个数,否则输出0 ...
随机推荐
- 每日算法——新型在线LCA
在线LCA一般大家都会用倍增吧,时间复杂度O(nlogn),空间复杂度O(nlogn),都是非常严格的复杂度限制,并且各种边界处理比较麻烦,有没有更快更好的办法呢? 我们发现,在树链剖分时,我们不经意 ...
- 【Leetcode】376. Wiggle Subsequence
Description: A sequence of numbers is called a wiggle sequence if the differences between successive ...
- KindEditor文本编辑框的实现
效果图: kindeditor 是一个插件 下载地址: https://files-cdn.cnblogs.com/files/lxnlxn/kindeditor.zip 解压后将其放在项目的js文件 ...
- css+js+html实现的遮罩
——————页面遮罩(CSS+JS+HTML)—————— HTML: <div id="mask" class="mask"></div&g ...
- Memcached 之分布式算法原理
memcached并不像mongodb一样可以配置多个节点,并且节点之间可以”自动分配数据“,即相互通信,所以我们在做memcache分布式集群的时候要有一个算法来保证当一台memcache服务器宕机 ...
- Phpstudy apache2 配置 https
我tm竟然搞了一下午 最终原因是因为443 端口被 SVN服务器占用了 一定要查看端口是否被占用 太深刻了这次 粗心大意 !!! 1:打开PHPstudy php扩展设置,在php_openssl上点 ...
- Java中StringTokenizer类的使用
StringTokenizer是一个用来分隔String的应用类,相当于VB的split函数. 1.构造函数 public StringTokenizer(String str) public Str ...
- SUSE 11 SP3 搭建weblogic服务
环境的搭建和业务需求相关,仅供参考 环境: SUSE 11 SP3 安装步骤 创建一个weblogic组 创建一个用户名为weblogic的用户, 创建相关目录 上传jdk,脚本等 安装 创建用户及其 ...
- 【编程工具】Vim编辑器的使用
1.Vim简介 Vim最初起源于古老的贝尔实验室,由"Bram Moolenaar等人"开发,是一个功能强大的文本编辑器,被推崇为类Vi编辑器中最好的一个. Vim是一个类 ...
- 蒟蒻的长链剖分学习笔记(例题:HOTEL加强版、重建计划)
长链剖分学习笔记 说到树的链剖,大多数人都会首先想到重链剖分.的确,目前重链剖分在OI中有更加多样化的应用,但它大多时候是替代不了长链剖分的. 重链剖分是把size最大的儿子当成重儿子,顾名思义长链剖 ...