题解 2020.10.24 考试 T4 模板
题目大意
有一个 \(n\) 个点组成的树,有 \(m\) 次操作,每次将 \(1\to x\) 的路径上每个点都加入一个颜色为 \(c\) 的小球。但是每个点都有大小限制,即小球个数超过一定量之后就不能再加入了。有 \(q\) 次查询,问操作完了之后每个点有多少种不同颜色的小球。
思路
stO llsw yyds Orz
以下皆为 llsw yyds 的思路,与本人无关。
我们首先可以整体二分出每一个点在多久会被填满,然后扫描线一波,问题就是如何判断一个子树内不同颜色的个数。这个我们可以直接容斥,就每次加入一个颜色的时候减掉与之前重复的即可。
时间复杂度 \(\Theta(n\log n)\)。
\(\texttt{Code}\)
#include <bits/stdc++.h>
using namespace std;
#define MAXN 100005
#define Int int
template <typename T> inline void read (T &t){t = 0;char c = getchar();int f = 1;while (c < '0' || c > '9'){if (c == '-') f = -f;c = getchar();}while (c >= '0' && c <= '9'){t = (t << 3) + (t << 1) + c - '0';c = getchar();} t *= f;}
template <typename T,typename ... Args> inline void read (T &t,Args&... args){read (t);read (args...);}
template <typename T> inline void write (T x){if (x < 0){x = -x;putchar ('-');}if (x > 9) write (x / 10);putchar (x % 10 + '0');}
vector <int> G[MAXN];
int n,m,uni,tmpc[MAXN];
struct Mod{
int u,c;
}seq[MAXN];
int ind,tur[MAXN],ans[MAXN],lim[MAXN],dfn[MAXN],dep[MAXN],siz[MAXN],par[MAXN][21];
void dfs (int u,int fa){
dfn[u] = ++ ind,tur[ind] = u,par[u][0] = fa,dep[u] = dep[fa] + 1,siz[u] = 1;
for (Int i = 1;i <= 20;++ i) par[u][i] = par[par[u][i - 1]][i - 1];
for (Int v : G[u]) if (v ^ fa) dfs (v,u),siz[u] += siz[v];
}
int getlca (int u,int v){
if (dep[u] < dep[v]) swap (u,v);
for (Int dis = dep[u] - dep[v],i = 20;~i;-- i) if (dis >> i & 1) u = par[u][i];
if (u == v) return u;
else{
for (Int i = 20;~i;-- i) if (par[u][i] ^ par[v][i]) u = par[u][i],v = par[v][i];
return par[u][0];
}
}
struct Bit_Tree{
int sum[MAXN];
int lowbit (int x){return x & (-x);}
void modify (int x,int v){for (Int i = x;i <= n;i += lowbit (i)) sum[i] += v;}
int query (int x){int res = 0;for (Int i = x;i;i -= lowbit (i)) res += sum[i];return res;}
int query (int l,int r){return query (r) - query (l - 1);}
}Tree;
vector <int> qry[MAXN];
void Solve (vector <int> &tmp,int l,int r){
if (tmp.empty()) return ;
if (l == r){
for (Int u : tmp) qry[l].push_back (u);
return tmp.clear();
}
vector <int> lson,rson;
int mid = (l + r) >> 1;
for (Int i = l ? l : 1;i <= mid;++ i) Tree.modify (dfn[seq[i].u],1);
for (Int u : tmp){
if (Tree.query (dfn[u],dfn[u] + siz[u] - 1) < lim[u]) rson.push_back (u);
else lson.push_back (u);
}
tmp.clear();
Solve (rson,mid + 1,r);
for (Int i = l ? l : 1;i <= mid;++ i) Tree.modify (dfn[seq[i].u],-1);
Solve (lson,l,mid);
}
set <int> colS[MAXN];
void Insert (set <int> &S,int u){
auto res = S.insert (dfn[u]);
if (!res.second) return ;
Tree.modify (dfn[u],1);
auto it = res.first;int p = -1,q = -1;
if (it != S.begin()) Tree.modify (dfn[getlca (u,p = tur[*-- it])],-1),++ it;
if (++ it != S.end()) Tree.modify (dfn[getlca (u,q = tur[*it])],-1);
if (~q && ~p) Tree.modify (dfn[getlca (p,q)],1);
}
signed main(){
read (n);
for (Int i = 2,u,v;i <= n;++ i) read (u,v),G[u].push_back (v),G[v].push_back (u);
for (Int i = 1;i <= n;++ i) read (lim[i]);
read (m);
for (Int i = 1;i <= m;++ i) read (seq[i].u,seq[i].c),tmpc[i] = seq[i].c;
sort (tmpc + 1,tmpc + m + 1),uni = unique (tmpc + 1,tmpc + m + 1) - tmpc - 1;
for (Int i = 1;i <= m;++ i) seq[i].c = lower_bound (tmpc + 1,tmpc + m + 1,seq[i].c) - tmpc;
dfs (1,0);
vector <int> tmp;for (Int i = 1;i <= n;++ i) tmp.push_back (i);
Solve (tmp,0,m);
for (Int i = 1;i <= m;++ i){
Insert (colS[seq[i].c],seq[i].u);
for (Int u : qry[i]) ans[u] = Tree.query (dfn[u],dfn[u] + siz[u] - 1);
}
int q;read (q);
for (Int i = 1,x;i <= q;++ i) read (x),write (ans[x]),putchar ('\n');
return 0;
}
题解 2020.10.24 考试 T4 模板的更多相关文章
- 题解 2020.10.24 考试 T2 选数
题目传送门 题目大意 见题面. 思路 本来以为zcx.pxj变强了,后来发现是SPJ出问题了...考试的时候感觉有点人均啊...结果自己还是只想出来一半. 我们假设 \(f(x)=(\lfloor\f ...
- 题解 2020.10.24 考试 T3 数列
题目传送门 题目大意 给出一个数 \(n\),你要构造一个数列,满足里面每个数都是 \(n\) 的因子,且每一个数与前面不互质的个数不超过 \(1\).问有多少种合法方案. 保证 \(n\) 的不同质 ...
- 10.24考试题解qwq
考点难度都很合适的一套题目,大概在day1到day2之前 T1 猴猴最喜欢在树上玩耍,一天猴猴又跳上了一棵树,这棵树有N个苹果,每个苹果有一个编号,分别为0~N-1,它们之间由N-1个树枝相连,猴猴可 ...
- 2020.10.24【普及组】模拟赛C组 总结
T1:暴力 1:先从 6 个中选三个,再把选出的三个全排列,全排列后再判断是否可行 2:把 6 个全都全排列,然后判断 T2:判断误差 1:减法时结果加上 1e-8 2:把小数乘上 1e6 左右 考试 ...
- T4 模板入门
T4,即4个T开头的英文字母组合:Text Template Transformation Toolkit.T4(Text Template Transformation Toolkit)是微软官方在 ...
- T4 模板
T4模板入门 T4,即4个T开头的英文字母组合:Text Template Transformation Toolkit.T4(Text Template Transformation Toolkit ...
- CSharpGL(12)用T4模板生成CSSL及其renderer代码
CSharpGL(12)用T4模板生成CSSL及其renderer代码 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharpGL源码中包含10多个独立 ...
- MVC实用架构设计(三)——EF-Code First(3):使用T4模板生成相似代码
前言 经过前面EF的<第一篇>与<第二篇>,我们的数据层功能已经较为完善了,但有不少代码相似度较高,比如负责实体映射的 EntityConfiguration,负责仓储操作的I ...
- 【转】- 使用T4模板批量生成代码
前言 之前在 “使用T4模板生成代码 - 初探” 文章简单的使用了T4模板的生成功能,但对于一个模板生成多个实例文件,如何实现这个方式呢?无意发现一个解决方案 “MultipleOutputHelpe ...
随机推荐
- Promise.race()
Promise.race([ ])---race竞赛,只要有一个决议了,就返回一个promise实例(对应resolve()或reject( )中参数值: 1.与Promise.all()对应的,还有 ...
- C# - 习题07_计算1分2分5分硬币各有多少枚
时间:2017-09-08 整理:byzqy 题目:现在有1分.2分.5分硬币共100个,总金额为2.46元,请用程序计算出1分.2分.5分各有多少枚,有多少种算法? 这是最近面试遇到的一个题目,刚开 ...
- 【Azure 应用服务】App Service For Windows 环境中部署Python站点后,如何继续访问静态资源文件呢(Serving Static Files)?
问题描述 当创建一个App Service 后,运行时环境和版本选择Windows 和 Python 3.6. 登录Kudu 站点查看,默认的文件有 web.config, hostingstart- ...
- 假期作业03:使用IDE开发你的Java程序
假期作业03:使用IDE开发你的Java程序 一.使用Eclipse创建一个Java项目HelloWorldPrj,编写一个Java程序并运行. 首先要下载eclipse. (注意这里要选一个中国的, ...
- Jenkins拉取Git远程仓库中指定目录至本地指定目录
Jenkins拉取源码是非常实用的操作,比如每天在跑自动化测试前,拉取Git远程仓库中最新的脚本至本地.那么,Jenkins如何拉取Git远程仓库中指定目录至本地指定目录呢?下面来看看具体的设置方法. ...
- Vue 2.0 与 Vue 3.0 响应式原理比较
Vue 2.0 的响应式是基于Object.defineProperty实现的 当你把一个普通的 JavaScript 对象传入 Vue 实例作为 data 选项,Vue 将遍历此对象所有的 prop ...
- 洛谷P2115 Sabotage G 题解
题目 [USACO14MAR]Sabotage G 题解 本蒟蒻又来了,这道题可以用二分答案来解决.我们可以设答案最小平均产奶量为 \(x \ (x \in[1,10000])\) .然后二分搜索 \ ...
- git02
Git Gui的使用 Ssh key 介绍及使用 Ssh key介绍 我理解的就是每台电脑上会产生出一个ssh key,然后自己有一个远程账户,但是自己有可能有很多台电脑, 包括家里的电脑还有公司的电 ...
- K8S——Pod
一.Pod概念 二.Pod存在的意义 三.Pod的实现机制 四.Pod镜像拉取策略 五.Pod资源限制 六.Pod重启机制 七.Pod的健康检查 八.Pod调度策略(创建Pod流程)
- Flex语法和常用鼠标手势
Flex弹性和模型 1.display : flex/inline-flex ;(设置给氟元素) flex : 将对象作为弹性伸缩盒显示: inline-flex : 将对象作为内联块级弹性伸缩显示: ...