CF 966E May Holidays
/*
考虑对于询问分块, 每根号n个询问做一次
考虑一次询问, 我们建立出虚树来每条链上的更改一定是一样的, 然后会有根号条链
对于每条链上的点按照w基数排序并且合并相同, 然后每次更改 就是一个指针移动一格, 根号n次更改每次都要枚举一遍所有的链 所以是On的
总体N\sqrt(N)
比着 DOFYPXY 的代码打的
*/
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<iostream>
#include<queue>
#include<cmath>
#define ll long long
#define M 100010
#define mmp make_pair
using namespace std;
int read() {
int nm = 0;
char c = getchar();
for(; !isdigit(c); c = getchar());
for(; isdigit(c); c = getchar()) nm = nm * 10 + c - '0';
return nm;
}
int n, m, tote, dft, ans, t[M], q[M], r[M], deep[M], top[M], son[M], sz[M], u[M], st[M], id[M], key[M], dfn[M], fa[M];
const int biao = 600;
vector<int> to[M], buc[M << 1];
bool b[M];
void dfs(int now, int f) {
deep[now] = deep[f] + 1;
sz[now] = 1;
for(int i = 0; i < to[now].size(); i++) {
int vj = to[now][i];
dfs(vj, now);
if(sz[son[now]] < sz[vj]) son[now] = vj;
sz[now] += sz[vj];
}
}
void dfs(int now) {
dfn[now] = ++dft;
if(son[now]) {
top[son[now]] = top[now];
dfs(son[now]);
}
for(int i = 0; i < to[now].size(); i++) {
int vj = to[now][i];
if(vj == son[now]) continue;
top[vj] = vj;
dfs(vj);
}
}
int lca(int a, int b) {
while(top[a] != top[b]) {
if(deep[top[a]] < deep[top[b]]) swap(a, b);
a = fa[top[a]];
}
if(deep[a] > deep[b]) swap(a, b);
return a;
}
bool cmp(int a, int b) {
return dfn[a] < dfn[b];
}
int rec(int now) {
int a = b[now];
for(int i = 0; i < to[now].size(); i++) {
int vj = to[now][i];
a += rec(vj);
}
r[now] = t[now] - a;
return a;
}
#define pii pair<int, int>
struct Note {
int hd, pnt, sum, dx;
vector<pii> s;
void clear() {
hd = pnt = sum = dx = 0;
vector<pii>().swap(s);
}
} g[M];
void work(int L, int R) {
rec(1);
for(int i = L; i <= R; i++) u[i - L] = q[i];
sort(u, u + R - L + 1, cmp);
int tp = 1, num = 1;
st[1] = key[1] = 1;
for(int i = 0; i <= R - L; i++) {
int A = lca(u[i], st[tp]);
while(deep[A] < deep[st[tp]]) {
if(deep[st[tp - 1]] <= deep[A]) {
g[st[tp--]].hd = A;
if(st[tp] != A) st[++tp] = A, key[++num] = A;
break;
}
g[st[tp]].hd = st[tp - 1];
tp--;
}
if(st[tp] != u[i]) st[++tp] = u[i], key[++num] = u[i];
}
for(; tp > 1; tp--) g[st[tp]].hd = st[tp - 1];
memset(id, 0, sizeof(id));
for(int i = 1; i <= num; i++) {
for(int p = fa[key[i]]; p != g[key[i]].hd; p = fa[p]) {
id[p] = key[i];
}
}
for(int i = 0; i <= (n << 1); i++) vector<int>().swap(buc[i]);
for(int i = 1; i <= n; i++) if(!b[i]) buc[r[i] + n].push_back(i);
for(int i = 0; i <= (n << 1); i++) {
for(int j = 0; j < buc[i].size(); j++) {
if(id[buc[i][j]]) {
int o = id[buc[i][j]], ss = g[o].s.size();
if(ss && g[o].s[ss - 1].first == i - n) g[o].s[ss - 1].second++;
else g[o].s.push_back(mmp(i - n, 1));
}
}
}
for(int i = 1; i <= num; i++)
for(int k = key[i]; g[k].pnt < g[k].s.size() && g[k].s[g[k].pnt].first < 0; g[k].pnt++);
for(int i = L; i <= R; i++) {
b[q[i]] ^= 1;
if(b[q[i]]) {
if(r[q[i]] < 0) ans--;
r[q[i]]--;
for(int p = q[i]; g[p].hd;) {
g[p].dx--;
if(g[p].pnt < g[p].s.size() && g[p].s[g[p].pnt].first + g[p].dx < 0) ans += g[p].s[g[p].pnt].second, g[p].pnt++;
p = g[p].hd, r[p]--;
if(b[p] == 0 && r[p] == -1) ans++;
}
} else {
r[q[i]]++;
if(r[q[i]] < 0) ans++;
for(int p = q[i]; g[p].hd;) {
g[p].dx++;
if(g[p].pnt && g[p].s[g[p].pnt - 1].first + g[p].dx >= 0) g[p].pnt--, ans -= g[p].s[g[p].pnt].second;
p = g[p].hd, r[p]++;
if(b[p] == 0 && r[p] == 0) ans--;
}
}
cout << ans << ' ';
}
for(int i = 1; i <= num; i++) g[key[i]].clear();
}
int main() {
n = read(), m = read();
for(int i = 2; i <= n; i++) fa[i] = read(), to[fa[i]].push_back(i);
dfs(1, 0);
top[1] = 1;
dfs(1);
for(int i = 1; i <= n; i++) t[i] = read();
for(int i = 1; i <= m; i++) q[i] = read();
for(int i = 1; i <= m; i += biao) work(i, min(i + biao - 1, m));
return 0;
}
CF 966E May Holidays的更多相关文章
- CF Gym 100187D Holidays (数学,递推)
题意:给n个元素,从n中选两个非空集合A和B.问有多少中选法? 递推: dp[n]表示元素个数为n的方案数,对于新来的一个元素,要么加入集合,要么不加入集合自成一个集合.加入集合有三种选择,A,B,E ...
- ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'
凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- cf Round 613
A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...
- ARC下OC对象和CF对象之间的桥接(bridge)
在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...
- [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现
1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...
- CF memsql Start[c]UP 2.0 A
CF memsql Start[c]UP 2.0 A A. Golden System time limit per test 1 second memory limit per test 256 m ...
- CF memsql Start[c]UP 2.0 B
CF memsql Start[c]UP 2.0 B B. Distributed Join time limit per test 1 second memory limit per test 25 ...
- CF #376 (Div. 2) C. dfs
1.CF #376 (Div. 2) C. Socks dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...
随机推荐
- create-react-app 搭建的项目中,使用 stylus
相关介绍文章: react学习系列1 修改create-react-app配置支持stylus:https://www.jianshu.com/p/9cd7a0dff11f 在react中使用styl ...
- Shell 一键安装命令
现在是懒人的天下,为了迎合用户的需求,很多开源软件或者包提供的安装步骤都非常简单,大家应该看到不少类似一键安装的命令.下面是几个典型的例子: # homebrew 安装 $ ruby -e " ...
- 逻辑回归(logic regression)的分类梯度下降
首先明白一个概念,什么是逻辑回归:所谓回归就是拟合,说明x是连续的:逻辑呢?就是True和False,也就是二分类:逻辑回归即使就是指对于二分类数据的拟合(划分). 那么什么是模型呢?模型其实就是函数 ...
- TestNG.xml参数配置-如何控制部分执行@test方法
如果在methods中标识了@test的方法,也可以在method中通过include和exclude来控制需要执行哪些方法 <include name="testMethod1&qu ...
- Spring Cloud(Dalston.SR5)--Feign 与 Hystrix 断路器整合
创建项目 要使 Feign 与 Hystrix 进行整合,我们需要增加 Feign 和 Hystrix 的依赖,修改 POM.xml 中增加以下依赖项如下: <?xmlversion=" ...
- mysql binlog to sql and show mysqlstatusadmin
sed '/WHERE/{:a;N;/SET/!ba;s/\([^\n]*\)\n\(.*\)\n\(.*\)/\3\n\2\n\1/}' 1.txt | sed -r '/WHERE/{:a;N;/ ...
- 在本机将本机的ip和mac绑定
cmd命令框中输入arp -s ip mac即可绑定 解除绑定:arp -d ip
- CAD中的各种Polyline
序号 类 类名 dxf代码 1 Polyline2d AcDb2dPolyline POLYLINE 2 Polyline3d AcDb3dPolyline POLYLINE 3 Polyline A ...
- elasticsearch mapping demo
curl -XPUT localhost:9200/local -d '{ "settings" : { "analysis" : { "analyz ...
- vue之过滤器
在vue2.0以前的版本中vue内置的过滤器,但是因为缺乏纯JavaScript的灵活性,现在vue2.0版本中已经删除了内置过滤器,所以需要自己注册过滤器,我们可以定义本地(在某一个template ...