题面:https://www.luogu.org/problemnew/lists?name=2146

这道题要用树链剖分,我博客里有对树链剖分的详细介绍

这道题就是树链剖分的模板,详细解释见程序。

学完树的dfs序,lca,线段树食用更佳。

不会这些学什么树剖(逃~

#include <bits/stdc++.h> //万能头文件
using namespace std;
int n,q,tot;
int fa[100005],size[100005],dep[100005],son[100005];
int lo[100005],top[100005];
int sum[800005],tag[800005];
vector <int> allson[100005];
//线段树
void pushup(int x)//更新
{
sum[x]=sum[x<<1]+sum[(x<<1)+1];
}
void pushdown(int x,int l,int r)//清除懒标记
{
if(tag[x]!=-1)
{
int m=(l+r)>>1;
int ls=x<<1;
int rs=ls+1;
tag[ls]=tag[rs]=tag[x];
sum[ls]=(m-l+1)*tag[x];
sum[rs]=(r-m)*tag[x];
tag[x]=-1;
}
}
void update(int x,int l,int r,int L,int R,int v)//修改
{
if(R<l||r<L)
return;
if(L<=l&&r<=R)
{
sum[x]=(r-l+1)*v;
tag[x]=v;
return;
}
pushdown(x,l,r);
int m=(l+r)>>1;
update(x<<1,l,m,L,R,v);
update((x<<1)+1,m+1,r,L,R,v);
pushup(x);
}
//树链剖分
void change(int x,int y,int v)//类似lca
{
int fx=top[x],fy=top[y];
while(fx!=fy)
{
if(dep[fx]<dep[fy])
swap(x,y),swap(fx,fy);
update(1,1,tot,lo[fx],lo[x],v);
x=fa[fx],fx=top[x];
}
if(lo[x]>lo[y])
swap(x,y);
update(1,1,tot,lo[x],lo[y],v);
}
void dfs1(int x)
{
size[x]=1;
for(int i=0;i<allson[x].size();++i)
{
int v=allson[x][i];
dep[v]=dep[x]+1;//深度
dfs1(v);
size[x]+=size[v];//子树大小
if(size[v]>size[son[x]])
son[x]=v;//重儿子
}
}
void dfs2(int x,int t)
{
lo[x]=++tot;
top[x]=t;//重链父亲
if(son[x])
dfs2(son[x],t);
for(int i=0;i<allson[x].size();++i)
{
int v=allson[x][i];
if(v!=son[x])
dfs2(v,v);
}
}
int main()
{
memset(tag,-1,sizeof(tag)); //lazy_tag为-1表示没有
ios::sync_with_stdio(0);
cin>>n;
fa[1]=1;
for(int i=2;i<=n;++i)
{
int x;
cin>>x;
fa[i]=x+1;
allson[x+1].push_back(i);
}
//预处理
dfs1(1);
dfs2(1,1);
cin>>q;
while(q--)
{
string s;
int x;
cin>>s>>x;
x++;
int before=sum[1];//改之前
if(s=="install")
{
change(1,x,1);//1到x路上全改成1
int after=sum[1];//改后
cout<<fabs(before-after)<<endl;
}
else
{
update(1,1,n,lo[x],lo[x]+size[x]-1,0);//把x的子树改成0
int after=sum[1];//改后
cout<<fabs(before-after)<<endl;
}
}
return 0;
}

【题解】Luogu P2146 [NOI2015]软件包管理器的更多相关文章

  1. 【luogu P2146 [NOI2015]软件包管理器】 题解

    题目链接:https://www.luogu.org/problemnew/show/P2146 变量名真毒瘤 我真的再也不把l,left,r,right弄反了 反向思维更好做一些 #include ...

  2. Luogu P2146 [NOI2015]软件包管理器 树剖

    卸载:把子树清空: 安装:把自己到$1$的链改为$1$ #include<cstdio> #include<iostream> #include<cstring> ...

  3. 题解 P2146 [NOI2015]软件包管理器

    P2146 [NOI2015]软件包管理器 感觉代码比其他题解更简洁qwq 树链剖分模板题 install x:将1~x的路径上的节点全部变成1(安装x需要先安装1~x) uninstall x:将x ...

  4. 洛谷 P2146 [NOI2015]软件包管理器 解题报告

    P2146 [NOI2015]软件包管理器 题目描述 Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软 ...

  5. [Luogu 2146] NOI2015 软件包管理器

    [Luogu 2146] NOI2015 软件包管理器 树剖好题. 通过对题目的分析发现,这些软件构成一棵树,\(0\) 是树根. 每下载一个软件,需要下载根到这个软件的路径上的所有软件: 每卸载一个 ...

  6. 洛谷 P2146 [NOI2015]软件包管理器 树链剖分

    目录 题面 题目链接 题目描述 输入输出格式 输入格式: 输出格式: 输入输出样例 输入样例#1: 输出样例#1: 输入样例#2: 输出样例#2: 说明 说明 思路 AC代码 总结 题面 题目链接 P ...

  7. P2146 [NOI2015]软件包管理器

    题目链接:https://www.luogu.org/problemnew/show/P2146 题目描述 Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安 ...

  8. 洛谷 P2146 [NOI2015]软件包管理器 (树链剖分模板题)

    题目描述 Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖(即下载安装这个 ...

  9. 【Luogu P2146】软件包管理器

    Luogu P2146 由于对于每一个软件包有且只有一个依赖的软件包,且依赖关系不存在环. 很显然这是一个树形的结构. 再看题目要求的操作,安装实际上对应的是覆盖根节点到当前节点的路径,卸载则是覆盖该 ...

随机推荐

  1. gem安装出错了

    1.首先是SSL出错. SSL 证书错误 正常情况下,你是不会遇到 SSL 证书错误的,除非你的 Ruby 安装方式不正确. 如果遇到 SSL 证书问题,你又无法解决,请修改 ~/.gemrc 文件, ...

  2. python 微信机器人,微信自动回复

    使用python现成的模块 itchat,可以实现,微信机器人的自动回复 其内部原理,是模拟了web版微信的登录,然后进行消息的接收发送,并不是只能用python实现,其他后端语言都可以做到 下面是使 ...

  3. 【转360】KB4041678 Windows 仅安全更新(2017.10) 补丁更新后执行SQL出错! http://bbs.360.cn/thread-15201531-1-1.html

    把EXCEL20003表数据导入到MDB数据库中sql命令语句\"SELECT * INTO 表 FROM [Excel 8.0;DATABASE=C:\\1.xls].[Sheet1$]\ ...

  4. css3径向渐变

    #grad2 { height: 440px; width: 440px; border-radius: %; background: -webkit-radial-gradient(closest- ...

  5. java基础(三) -基本数据类型

    变量就是申请内存来存储值.也就是说,当创建变量的时候,需要在内存中申请空间. 内存管理系统根据变量的类型为变量分配存储空间,分配的空间只能用来储存该类型数据. 因此,通过定义不同类型的变量,可以在内存 ...

  6. AIX挂载NFS写入效率低效解决

    背景: Linux是NFS的Server端,AIX是NFS的Client端(此外,有一个Linux也作为Client端对比测试). 1.NFS对应的底层设备是闪存卡,本地测试I/O写性能可达2GB/s ...

  7. php url链接地址传数组方法 json_decode解析数组失败 经过url链接的json数组解析出错的解决方法 (原)

    先说出现的问题: 请求一个接口(例如  http://www.a.com/getmes.php)需要传一个数组参数 param ,值为 数组 array(0=>'刘师傅',1=>'1760 ...

  8. linux 系统 cp: omitting directory 问题解决

    在linux系统中复制文件夹时提示如下: cp: omitting directory `foldera/' 其中foldera是我要复制的文件夹名,出现该警告的原因是因为foldera目录下还存在目 ...

  9. SpringMVC.入门篇.一.HelloWorld

    SpringMVC.入门篇<一>HelloWorld 项目包结构如下: HelloController.java 代码 package com.charles.controller; im ...

  10. SqlServer表和EXCEL数据互相复制方法

    一.SqlServer表数据复制到excel 1.新建查询,用sql语句把表数据读出来 2.然后,选择数据,右键,复制(也可以点击连同标题复制),复制到记事本中(不然会乱码) 3.然后再把记事本的内容 ...