bzoj 4196: [Noi2015]软件包管理器
Description
Linux用户和OSX用户一定对软件包管理器不会陌生。通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖(即下载安装这个软件包的安装所依赖的其它软件包),完成所有的配置。Debian/Ubuntu使用的apt-get,Fedora/CentOS使用的yum,以及OSX下可用的homebrew都是优秀的软件包管理器。
Input
输入文件的第1行包含1个正整数n,表示软件包的总数。软件包从0开始编号。
Output
输出文件包括q行。
Sample Input
0 0 0 1 1 5
5
install 5
install 6
uninstall 1
install 4
uninstall 0
Sample Output
1
3
2
3
HINT
一开始所有的软件包都处于未安装状态。
Source
传说中的树链剖分大果题。。。闲的没事干,发现竟然连线段树都能打错
安装:查询x到根的0的个数,并把路径赋为1;
删除:查询x的子树中1的个数,并把子树赋为0;
所以只有区间覆盖和区间求和操作,zz选手竟然打了1.5h...
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define ls x<<1
#define rs x<<1|1
using namespace std;
const int N=300000;
int tt,dfn[N],size[N],top[N],son[N],deep[N],fa[N],head[N],to[N],nxt[N],cnt;
int lazy[N*4],tr[N*4],n,m;
char ch[N];
void dfs1(int x,int f){
size[x]=1;deep[x]=deep[f]+1;
for(int i=head[x];i;i=nxt[i]){
int y=to[i];
if(y!=f){
dfs1(y,x);fa[y]=x;
size[x]+=size[y];
if(size[y]>size[son[x]]) son[x]=y;
}
}
}
void dfs2(int x,int f){
top[x]=f;dfn[x]=++tt;
if(son[x]) dfs2(son[x],f);
for(int i=head[x];i;i=nxt[i]){
int y=to[i];
if(y!=fa[x]&&y!=son[x]) dfs2(y,y);
}
}
void pushdown(int x,int l,int r){
if(lazy[x]==1){
lazy[ls]=lazy[rs]=1;lazy[x]=0;
tr[ls]=tr[rs]=0;
}
else{
lazy[ls]=lazy[rs]=2;lazy[x]=0;
int mid=(l+r)>>1;
tr[ls]=mid-l+1;tr[rs]=r-mid;
}
}
void pushup(int x){tr[x]=tr[ls]+tr[rs];}
int query(int x,int L,int R,int xl,int xr,int flag){
if(xl<=L&&R<=xr) return tr[x];
if(lazy[x]) pushdown(x,L,R);
int mid=(L+R)>>1;
if(xr<=mid) return query(ls,L,mid,xl,xr,flag);
else if(xl>mid) return query(rs,mid+1,R,xl,xr,flag);
else return query(ls,L,mid,xl,mid,flag)+query(rs,mid+1,R,mid+1,xr,flag);
}
void update(int x,int L,int R,int xl,int xr,int flag){
if(xl<=L&&R<=xr){
lazy[x]=flag;
if(flag==1) tr[x]=0;
else tr[x]=R-L+1;
return;
}
int mid=(L+R)>>1;
if(lazy[x]) pushdown(x,L,R);
if(xr<=mid) update(ls,L,mid,xl,xr,flag);
else if(xl>mid) update(rs,mid+1,R,xl,xr,flag);
else update(ls,L,mid,xl,mid,flag),update(rs,mid+1,R,mid+1,xr,flag);
pushup(x);
}
void work1(int x){
int ret=0;
while(x){
int r=dfn[x],l=dfn[top[x]];
ret+=r-l+1-query(1,1,n,l,r,2);
update(1,1,n,l,r,2);x=fa[top[x]];
}
printf("%d\n",ret);
}
void work2(int x){
printf("%d\n",query(1,1,n,dfn[x],dfn[x]+size[x]-1,2));
update(1,1,n,dfn[x],dfn[x]+size[x]-1,1);
}
void lnk(int x,int y){
to[++cnt]=y,nxt[cnt]=head[x],head[x]=cnt;
to[++cnt]=x,nxt[cnt]=head[y],head[y]=cnt;
}
int main(){
freopen("1.in","r",stdin);
freopen("1.out","w",stdout);
scanf("%d",&n);
for(int i=2;i<=n;i++){
int x;scanf("%d",&x);x++;lnk(i,x);
}
dfs1(1,0);dfs2(1,1);
scanf("%d",&m);
for(int i=1;i<=m;i++){
scanf("%s",ch+1);
int x;scanf("%d",&x);x++;
if(ch[1]=='i') work1(x);
else work2(x);
}
return 0;
}
bzoj 4196: [Noi2015]软件包管理器的更多相关文章
- BZOJ 4196: [Noi2015]软件包管理器 [树链剖分 DFS序]
4196: [Noi2015]软件包管理器 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1352 Solved: 780[Submit][Stat ...
- Bzoj 4196: [Noi2015]软件包管理器 树链剖分
4196: [Noi2015]软件包管理器 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 721 Solved: 419[Submit][Statu ...
- bzoj 4196 [Noi2015]软件包管理器 (树链剖分+线段树)
4196: [Noi2015]软件包管理器 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 2852 Solved: 1668[Submit][Sta ...
- 【刷题】BZOJ 4196 [Noi2015]软件包管理器
Description Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖( ...
- 4196. [NOI2015]软件包管理器【树链剖分】
Description Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖( ...
- 4196: [Noi2015]软件包管理器
Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 412 Solved: 251[Submit][Status][Discuss] Descriptio ...
- [BZOJ4196][NOI2015]软件包管理器
4196: [Noi2015]软件包管理器 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1040 Solved: 603[Submit][Stat ...
- [BZOJ4196][NOI2015]软件包管理器(树链剖分)
4196: [Noi2015]软件包管理器 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 2166 Solved: 1253[Submit][Sta ...
- [NOI2015]软件包管理器
4621 [NOI2015]软件包管理器 题目等级 : 钻石 Diamond 题目描述 Description Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过 ...
随机推荐
- KNN--用于手写数字识别
优点:精度高,对异常值不敏感,无数据输入假定 缺点:计算复杂度高,空间复杂度高 适用数据范围:数值型和标称型 一般流程: (1). 收集数据(网络抓取) (2).处理数据,将数据处 ...
- Mysql基础--表的操作
1.表的基本概念 每一行代表一条唯一的记录,每一列代表记录中的一个字段. 2.创建表 例子: 3.查看表结构 (1)DESCRIBE语句查看表定义 语法: 例子: (2)SHOW CREATE TAB ...
- zzuli 1816: 矩形 排序思维
1816: 矩形 Time Limit: 1 Sec Memory Limit: 128 MB Submit: 179 Solved: 54 SubmitStatusWeb Board Descr ...
- 初识java这个小姑娘(三)
说烂了的面向对象 我要说的面向对象,其实是一个我自己都觉的有点恶心的东西. 它是java语言入门如此初级的一个概念.作为一个老鸟,你可以吐口水给我,我可以把它们擦干,但作为总结还得说一说. 因为对于一 ...
- C++ IO操作API及注意事项(包含一个日志类的实现)
C++是一个抽象程度比C高很多的语言,在使用C++时,编译器做了很多工作,如果我们不对C++的某些特性的实现机制进行了解,那么编程时也许会有很多疑惑,我们也许知道怎样做才是正确的,但不知道为什么要这样 ...
- Scala入门系列(十三):类型参数
引言 Scala中类型参数是什么呢?其实就类似于Java中的泛型.定义一种类型参数,比如在集合.类.函数中定义类型参数,然后就可以保证使用到该类型参数的地方就只能是这种类型,从而实现程序更好的健壮性. ...
- loadrunner 录制TCP协议脚本操作
测试TCP协议的项目,涉及到登陆.发送实时数据.指令.登出等,直接写报文工作量太大,所以需要录制报文. 操作方法如下: 1.启动服务端程序 2.使用winsocket协议 3.选择应用程序 4.录制选 ...
- KNN K~近邻算法笔记
K~近邻算法是最简单的机器学习算法.工作原理就是:将新数据的每一个特征与样本集中数据相应的特征进行比較.然后算法提取样本集中特征最相似的数据的分类标签.一般来说.仅仅提取样本数据集中前K个最相似的数据 ...
- java 可变參数
我们在某些特定的需求环境下,可能要对某一个方法中的參数进行一些操作,并且这些方法中的參数是不规定的,那么问题来了,我们该怎么办呢? java事实上就为我们考虑了这样的情况,那就是使用可变參数 可变參数 ...
- [开源项目] Android校验库 - FireEye
简单易用的Android校验库. 这是一个简单Android校验库,按配置来验证用户输入的表单信息. 仅仅须要几行代码,就可以验证用户输入,而且将验证错误反馈给用户. 它内置了大量经常使用的验证类型, ...