软件包管理器(bzoj 4196)
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
一开始所有的软件包都处于未安装状态。
/*
安装就是安装一条链,可用树链剖分,删除就是删除一棵子树,根据dfs序的性质,他们是在一段连续的区间上,所以也可以用树链剖分解决。
*/
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 100010
#define lson l,mid,rt<<1
#define rson mid+1,r,rt<<1|1
using namespace std;
int n,cnt,tot,root;
struct node{
int to,pre;
};node e[N];
int head[N],fa[N],size[N],dep[N],son[N],top[N],pos[N],end[N],sum[N*],tag[N*],col[N*];
void init(){
memset(head,-,sizeof(head));
cnt=;
}
void add(int from,int to){
e[cnt].to=to;
e[cnt].pre=head[from];
head[from]=cnt++;
}
void dfs1(int now){
size[now]=,son[now]=-;
for(int i=head[now];i!=-;i=e[i].pre){
int to=e[i].to;
if(to==fa[now])continue;
dep[to]=dep[now]+;
fa[to]=now;
dfs1(to);
size[now]+=size[to];
if(son[now]==-||size[son[now]]<size[to])son[now]=to;
}
}
void dfs2(int now,int tp){
top[now]=tp,pos[now]=++tot;
if(son[now]!=-)dfs2(son[now],tp);
for(int i=head[now];i!=-;i=e[i].pre){
int to=e[i].to;
if(to==fa[now]||to==son[now])continue;
dfs2(to,to);
}
end[now]=tot;
}
void pushup(int rt){
sum[rt]=sum[rt<<]+sum[rt<<|];
}
void pushdown(int rt,int m){
if(tag[rt]){
sum[rt<<]=(m-(m>>))*col[rt];
sum[rt<<|]=(m>>)*col[rt];
tag[rt<<]=,tag[rt<<|]=;
col[rt<<]=col[rt];
col[rt<<|]=col[rt];
tag[rt]=;
}
}
void update(int L,int R,int l,int r,int rt,int jd){
if(L<=l&&r<=R){
tag[rt]=,col[rt]=jd,sum[rt]=(r-l+)*jd;
return;
}
int mid=(l+r)>>;
pushdown(rt,r-l+);
if(L<=mid)update(L,R,lson,jd);
if(R>mid)update(L,R,rson,jd);
pushup(rt);
}
int query(int L,int R,int l,int r,int rt,int jd){
if(L<=l&&r<=R)return sum[rt];
pushdown(rt,r-l+);
int ret=;
int mid=(l+r)>>;
if(L<=mid)ret+=query(L,R,lson,jd);
if(R>mid)ret+=query(L,R,rson,jd);
//pushup(rt);
return ret;
}
int install(int x,int y){
int ans=;
ans=query(,n,,n,,);
while(top[x]!=top[y]){
if(dep[top[x]]<dep[top[y]])swap(x,y);
int l=pos[top[x]],r=pos[x];
update(l,r,,n,,);
x=fa[top[x]];
}
if(dep[x]>dep[y])swap(x,y);
int l=pos[x],r=pos[y];
update(l,r,,n,,);
ans=query(,n,,n,,)-ans;
return ans;
}
char s[];
int main(){
init();
scanf("%d",&n);
for(int i=;i<=n;i++){
int x;scanf("%d",&x);x++;
add(x,i);
}
dfs1();dfs2(,);
int q;
scanf("%d",&q);
while(q--){
scanf("%s",s);
int x;
if(s[]=='i'){
scanf("%d",&x);x++;
printf("%d\n",install(,x));
}
else{
scanf("%d",&x);x++;
int l=pos[x],r=end[x];
int ans=query(,n,,n,,);
update(l,r,,n,,);
ans-=query(,n,,n,,);
printf("%d\n",ans);
}
}
}
软件包管理器(bzoj 4196)的更多相关文章
- 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用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖( ...
- 【刷题】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 软件包管理器
Description Linux用户和OSX用户一定对软件包管理器不会陌生. 通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖 ...
随机推荐
- 允许Java App(applet)粘贴方法
修改安全策略文件: "java.policy" JRE6的路径在:"C:\Program Files (x86)\Java\jre6\lib\security" ...
- 通过90行代码学会HTML5 WebSQL的4种基本操作
Web SQL数据库API是一个独立的规范,在浏览器层面提供了本地对结构化数据的存储,已经被很多现代浏览器支持了. 我们通过一个简单的例子来了解下如何使用Web SQL API在浏览器端创建数据库表并 ...
- git快速入门(MAC系统,github,ssh key)
如果使用过svn的话,git大致可以认为是多了本地库的svn.git先本地提交commit到本地库,然后再push到远程服务器的库.git是分布式的代码管理工具,基于SSH协议.ssh的作用就是为了不 ...
- postcss.config.js配置文件的配置方法
module.exports = { plugins: { 'autoprefixer': {}, } }
- js中的跨域方法总结
什么是跨域? 浏览器的安全策略,只要协议,域名,端口有任何一个不同,就被当做不同的域. 下面对http://www.qichedaquan.com的同源检测 http://www.qichedaqua ...
- 洛谷P1001 A+B Problem
这道题…………还是很简单!!! code: #include <iostream> #include <cstdio> using namespace std; int mai ...
- golang 实现冒泡排序
package main import ( "fmt" ) func main(){ a := [...] int{2,5,9,6,8} fmt.Println(a) num := ...
- 刚毕业去面试Python工程师,这几道题太难了,Python面试题No11
写在前面 本想停一段时间这个系列,但是好多朋友给我发信息说让我继续整理下去,so,继续吧~ 第1题: docstring是什么? docstring是一种文档字符串,用于解释构造的作用.我们在函数.类 ...
- python--内置函数03
一 . 正则表达式 匹配字符串 元字符 . 除了换行 \w 数字, 字母, 下划线 \d 数字 \s 空白符 \n \t \b 单词的边界 \W 非xxx \D \S [ ] 字符组 or的关系 [^ ...
- 快速入门Sklearn
主要确定sklearn的基本流程,然后把sklearn当做螺丝刀来用就行了,需要什么查什么. 基本流程 首先我们回顾一下机器学习的基本流程: 特征工程,包括了数据清洗,数据标准版化,特征选取,特征降维 ...