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
一开始所有的软件包都处于未安装状态。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstdlib>
#define MAX (100000+5)
using namespace std;
struct node
{
int val;
int mark;
}Segt[MAX*];
struct node1
{
int to;
int next;
}edge[MAX*];
int Father[MAX],Depth[MAX];
int Sum[MAX],Son[MAX],Top[MAX];
int T_num[MAX];
int num_edge,head[MAX],n,p,x,cnt;
int a[MAX];
char r[]; void add(int u,int v)
{
edge[++num_edge].to=v;
edge[num_edge].next=head[u];
head[u]=num_edge;
} void Dfs1(int x)
{
Sum[x]=;
Depth[x]+=Depth[Father[x]]+(x!=);
for (int i=head[x];i!=;i=edge[i].next)
if (edge[i].to!=Father[x])
{
Father[edge[i].to]=x;
Dfs1(edge[i].to);
Sum[x]+=Sum[edge[i].to];
if (!Son[x] ||Sum[edge[i].to]>Sum[Son[x]])
Son[x]=edge[i].to;
}
} void Dfs2(int x,int pre)
{
T_num[x]=++cnt;
Top[x]=pre;
if (Son[x])
Dfs2(Son[x],pre);
for (int i=head[x];i!=;i=edge[i].next)
if (edge[i].to!=Son[x] && edge[i].to !=Father[x])
Dfs2(edge[i].to,edge[i].to);
} void Pushdown(int node,int l,int r)
{
if (Segt[node].mark==)
{
Segt[node<<].mark=;
Segt[node<<|].mark=;
int mid=(l+r)>>;
Segt[node<<].val=mid-l+;
Segt[node<<|].val=r-mid;
Segt[node].mark=;
}
if (Segt[node].mark==-)
{
Segt[node<<].mark=-;
Segt[node<<|].mark=-;
int mid=(l+r)>>;
Segt[node<<].val=;
Segt[node<<|].val=;
Segt[node].mark=;
}
} void Update(int node,int l,int r,int l1,int r1,int k)
{
if (l>r1 || r<l1) return;
if (l1<=l && r<=r1)
{
Segt[node].val=(r-l+)*k;
Segt[node].mark=k==?-:;
}
else
{
Pushdown(node,l,r);
int mid=(l+r)>>;
Update(node<<,l,mid,l1,r1,k);
Update(node<<|,mid+,r,l1,r1,k);
Segt[node].val=Segt[node<<].val+Segt[node<<|].val;
}
} int Query(int node,int l,int r,int l1,int r1)
{
if (l>r1 || r<l1) return ;
if (l1<=l && r<=r1)
return Segt[node].val;
else
{
Pushdown(node,l,r);
int mid=(l+r)>>;
return Query(node<<,l,mid,l1,r1)+
Query(node<<|,mid+,r,l1,r1);
}
} void Work1(int x)
{
int sum=Depth[x]+;
int cnt=;
while (x!=-)
{
cnt+=Query(,,n,T_num[Top[x]],T_num[x]);
Update(,,n,T_num[Top[x]],T_num[x],);
x=Father[Top[x]];
}
printf("%d\n",sum-cnt);
} void Work2(int x)
{
printf("%d\n",Query(,,n,T_num[x],T_num[x]+Sum[x]-));
Update(,,n,T_num[x],T_num[x]+Sum[x]-,);
} int main()
{
scanf("%d",&n);
for (int i=;i<=n-;++i)
{
scanf("%d",&x);
add(i,x);add(x,i);
}
Dfs1();
Dfs2(,);
Father[]=-;
scanf("%d",&p);
for (int i=;i<=p;++i)
{
scanf("%s%d",r,&x);
if (r[]=='i')
Work1(x);
if (r[]=='u')
Work2(x);
}
}
4196. [NOI2015]软件包管理器【树链剖分】的更多相关文章
- 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]软件包管理器 [树链剖分 DFS序]
4196: [Noi2015]软件包管理器 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1352 Solved: 780[Submit][Stat ...
- 【BZOJ4196】[Noi2015]软件包管理器 树链剖分
[Noi2015]软件包管理器 树链剖分 Description Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从 ...
- [BZOJ4196][NOI2015]软件包管理器(树链剖分)
4196: [Noi2015]软件包管理器 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 2166 Solved: 1253[Submit][Sta ...
- 洛谷 P2146 [NOI2015]软件包管理器 树链剖分
目录 题面 题目链接 题目描述 输入输出格式 输入格式: 输出格式: 输入输出样例 输入样例#1: 输出样例#1: 输入样例#2: 输出样例#2: 说明 说明 思路 AC代码 总结 题面 题目链接 P ...
- 【bzoj4196】[Noi2015]软件包管理器 树链剖分+线段树
题目描述 Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖(即下载安装这个 ...
- bzoj4196 [Noi2015]软件包管理器——树链剖分
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4196 树链剖分. 代码如下: #include<iostream> #inclu ...
- NOI2015 软件包管理器(树链剖分+线段树)
P2146 软件包管理器 题目描述 Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决 ...
- [NOI2015]软件包管理器-树链剖分
#include<bits/stdc++.h> using namespace std; const int maxn = 1e6+5; int n,m; int e,begin[maxn ...
随机推荐
- jquery select change下拉框选项变化判断选中值
<th class="formTitle"> 是否转出: </th> <td class="formValue" colspan= ...
- ubuntu 常见错误--Could not get lock /var/lib/dpkg/lock 问题修改
ubuntu 常见错误–Could not get lock /var/lib/dpkg/lock 通过终端安装程序sudo apt-get install xxx或者apt-get update时出 ...
- spring事务注解失效问题
问题描述: 由于工作需要,需要在spring中配置两个数据源,有一天突然发现@Transactional注解失效 环境框架: springmvc+spring+spring jdbcTemplate ...
- Recommend ways to overwrite hashCode() in java
Perface In the former chapter, I talk about topics about hashCode, And I will continue to finish the ...
- sql按月统计数量和按月累加统计数量
1.简单的,按月统计数量 SELECT CREATE_DATE, DATE_FORMAT(CREATE_DATE, '%Y-%m') AS month , COUNT(*) AS sum FROM p ...
- java工程师_基础_阶段一_HTML笔记篇
一.了解HTML语言 html:超文本标记语言. 二.HTML整体结构<html> <head> </head> <body> </body> ...
- js/jq 倒计时插件(一)
//很多时候我们需要用到倒计时比如(一些发布会倒计时,秒杀倒计时,活动倒计时等),接下来将介绍两种倒计时插件的写法 //html结构 <!DOCTYPE html> <html la ...
- 180328_gVim设置tab为4个空格
找到gVim安装目录 C:\Program Files (x86)\Vim\ 更改目录下的 _vimrc 文件,这是一个只读文件,需要管理员权限进行修改和保存. 在文件末尾添加下列内容: set ts ...
- python汉字转拼音
上代码: #!/usr/bin/env python # -*- coding:utf-8 -*- """ Author:cleverdeng E-mail:clverd ...
- 【转】数据分析与处理之二(Leveldb 实现原理)
郑重声明:本篇博客是自己学习 Leveldb 实现原理时参考了郎格科技系列博客整理的,原文地址:http://www.samecity.com/blog/Index.asp?SortID=12,只是为 ...