P4074-[WC2013]糖果公园【树上带修莫队】

正题

题目链接:https://www.luogu.com.cn/problem/P4074


题目大意

nnn个点的一颗数,第iii个点有一颗cic_ici种类的糖。

iii次获得jjj种类的糖可以产生价值wi∗vjw_i*v_jwivj

每次操作

  1. 修改一个点的糖果种类
  2. 询问一个路径的价值和

解题思路

用欧拉序可以做到在树上进行莫队,然后带修即可。


codecodecode

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#define ll long long
using namespace std;
const ll N=2e5+10;
struct q_node{ll id,t,l,r;
}q[N];
struct node{ll to,next;
}a[N*2];
ll n,m,Q,T,cnt,tot,answer;
ll v[N],w[N],c[N],ans[N],ls[N];
ll cho[N],cval[N],pre[N];
ll dfn[N],rfn[N],ed[N],ok[N];
ll f[N][21],dep[N],vis[N];
bool operator<(q_node x,q_node y){if(x.l/T!=y.l/T)return x.l/T<y.l/T;if(x.r/T!=y.r/T)return x.r/T<y.r/T;return x.t/T<y.t/T;
}
void addl(ll x,ll y){a[++tot].to=y;a[tot].next=ls[x];ls[x]=tot;return;
}
void dfs(ll x,ll fa){dfn[++cnt]=x;rfn[x]=cnt;for(ll i=ls[x];i;i=a[i].next){ll y=a[i].to;if(y==fa)continue;f[y][0]=x;dep[y]=dep[x]+1; dfs(y,x);}dfn[++cnt]=x;ed[x]=cnt; 
} 
void ycl(){for(ll i=1;i<=20;i++)for(ll j=1;j<=n;j++)f[j][i]=f[f[j][i-1]][i-1];return;
}
ll LCA(ll x,ll y){if(dep[y]>dep[x])swap(x,y);for(ll i=20;i>=0;i--)if(dep[f[x][i]]>=dep[y])x=f[x][i];if(x==y)return x;for(ll i=20;i>=0;i--)if(f[y][i]!=f[x][i])x=f[x][i],y=f[y][i];return f[x][0];
}
void rev(ll x){int k=c[x];if(ok[x])answer-=w[vis[k]]*v[k],vis[k]--;else vis[k]++,answer+=w[vis[k]]*v[k];ok[x]^=1;return;
}
void keep(ll &l,ll &r,ll &t,ll L,ll R,ll T){while(l<L)rev(dfn[l]),l++;while(l>L)l--,rev(dfn[l]);while(r<R)r++,rev(dfn[r]);while(r>R)rev(dfn[r]),r--;while(t<T){t++;ll x=cho[t],flag=0;if(ok[x])rev(x),flag=1;swap(c[x],cval[t]);if(flag)rev(x);}while(t>T){ll x=cho[t],flag=0;if(ok[x])rev(x),flag=1;swap(c[x],cval[t]);if(flag)rev(x);t--;}
}
int main()
{scanf("%lld%lld%lld",&n,&m,&Q);for(ll i=1;i<=m;i++)scanf("%lld",&v[i]);for(ll i=1;i<=n;i++)scanf("%lld",&w[i]);for(ll i=1;i<n;i++){ll x,y;scanf("%lld%lld",&x,&y);addl(x,y);addl(y,x);}for(ll i=1;i<=n;i++)scanf("%lld",&c[i]);dep[1]=1;dfs(1,0);ycl();cnt=tot=0;for(ll i=1;i<=Q;i++){ll op,x,y;scanf("%lld",&op);if(op==0){tot++;scanf("%lld%lld",&cho[tot],&cval[tot]);}else{scanf("%lld%lld",&x,&y);if(rfn[x]>rfn[y])swap(x,y);int lca=LCA(x,y);if(lca==x||lca==y)x=rfn[x],y=rfn[y];else x=ed[x],y=rfn[y];q[++cnt]=(q_node){cnt,tot,x,y};}}T=pow(n,2.0/3);sort(q+1,q+1+cnt);ll l=1,r=0,t=0;for(ll i=1;i<=cnt;i++){ll x=q[i].l,y=q[i].r;keep(l,r,t,x,y,q[i].t);ll lca=LCA(dfn[x],dfn[y]),flag=0;if(dfn[x]!=lca&&dfn[y]!=lca){flag=1;vis[c[lca]]++;answer+=w[vis[c[lca]]]*v[c[lca]];}ans[q[i].id]=answer;if(flag){answer-=w[vis[c[lca]]]*v[c[lca]];vis[c[lca]]--;}}for(ll i=1;i<=cnt;i++)printf("%lld\n",ans[i]);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/321276.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

闲来无事刷水题、简单博弈论专题、sg函数、洛谷

记 今天闲来无事&#xff0c;不想刷codeforces了&#xff0c;到洛谷提高组训练营找几道水题刷着玩玩&#xff08;虽然自己早已过了打OI的年纪&#xff09;&#xff5e; 简单博弈论专题 P1199 三国游戏 这么考虑&#xff0c;由于电脑总是不能让我搭配出当前能搭配出的最大的…

医院(jzoj 1611)

医院 题目大意&#xff1a; 有n个城市&#xff0c;有m条线路使他们相连&#xff08;有向&#xff09;&#xff0c; 在一些城市中建立医院&#xff0c;相连的城市只能有一间医院&#xff0c;每个医院可以派医生去别的城市&#xff0c;当医生走的线路>3时&#xff0c;他们会…

2019.01.24【NOIP普及组】模拟赛C组

总结 这一次的分数&#xff1a;1002562.562.5250 第一题老实打完&#xff0c;100分&#xff0c;第二题蒙点25分&#xff0c;第三题只打了Floyed&#xff0c;还有一部分&#xff08;匈牙利算法&#xff09;没打&#xff0c;第四题蒙点特判&#xff0c;62.5,&#xff08;说实在我…

nssl1453-Fibonacci数列【矩阵乘法,线段树】

正题 题目大意 给出nnn和si(i∈[0..n−1])s_i(i\in[0..n-1])si​(i∈[0..n−1])&#xff0c;对于大部分情况有sxsx%ns_xs_{x\%n}sx​sx%n​。 有递推式FiFi−1si−1Fi−2si−2F_iF_{i-1}s_{i-1}F_{i-2}s_{i-2}Fi​Fi−1​si−1​Fi−2​si−2​ 有mmm个情况的sx!sx%ns_x!s_{…

Apache SkyWalking 为.NET Core带来开箱即用的分布式追踪和应用性能监控

在大型网站系统设计中&#xff0c;随着分布式架构&#xff0c;特别是微服务架构的流行&#xff0c;我们将系统解耦成更小的单元&#xff0c;通过不断的添加新的、小的模块或者重用已经有的模块来构建复杂的系统。随着模块的不断增多&#xff0c;一次请求可能会涉及到十几个甚至…

洛谷 P1967货车运输 并查集+贪心 不需要用LCA!

题目链接 题目链接 题解 要求所有的路径中最小边长的最大值&#xff01; 我们贪心的加边&#xff0c;依照边从大往小的方式往里添加&#xff0c;然后合并并查集。 每次当查询分布在两个待合并的并查集的时候&#xff0c;当前的边长就是这次查询的答案。 我们对每个并查集…

【图论】【最短路】【SPFA】香甜的黄油 Sweet Butter (luogu 1828)

香甜的黄油 Sweet Butter luogu 1828 题目大意&#xff1a; 有n头奶牛&#xff0c;他们在不同的牧场中&#xff0c;他们之间有一些路&#xff0c;现在要让他们去一个地方吃黄油&#xff0c;使他们的总距离最小 题目描述 农夫John发现做出全威斯康辛州最甜的黄油的方法&…

P1081 开车旅行 倍增 洛谷

题目连接 题意 题目已经说的hin明确了。 题解 我们要求出从每个点出发&#xff0c;小A要走的城市和小B要走的城市。 我们把ii以后的所有点的海拔加入到set" role="presentation" style="position: relative;">setset&#xff0c;然后拿H[i]H[…

nssl1454-最短路【并查集,贪心】

正题 题目大意 nnn个点&#xff0c;每个点可以走到[ai,n][a_i,n][ai​,n]&#xff0c;每个点可以从[bi,n][b_i,n][bi​,n]到达。 求disi,j∗(ij)dis_{i,j}*(ij)disi,j​∗(ij)的异或和 解题思路 首先我们可以知道肯定是先往后跳再往前走最优&#xff0c;因为如果先往前再往后…

.NET Core 跨平台执行命令、脚本

一.前言我们可能会遇到需要在程序中执行一些系统命令&#xff0c;来获取一些信息&#xff1b;或者调用shell脚本。.NET Core 目前已经可以跨平台执行&#xff0c;那么它如何跨平台执行命令呢&#xff0c;请看下面的讲解。二.ProcessStartInfo、Process 类介绍我们主要用到的两个…

nssl1458-HR 的疑惑【枚举】

正题 题目大意 给出nnn&#xff0c;求[1..n][1..n][1..n]中有多少个数可以被ab(b>1)a^b(b>1)ab(b>1)表示 解题思路 首先如果bbb等于222&#xff0c;那么可以被表示的数就是n\sqrt nn​个 bbb不是质数时&#xff0c;显然所以的数都可以被一个bbb是质数的情况表示。 …

性能是.NET Core的一个关键特性

关键要点.NET Core是跨平台的&#xff0c;可运行在Windows、Linux、Mac OS X和更多平台上&#xff1b;与.NET相比&#xff0c;发布周期要短得多。大多数.NET Core 都是通过NuGet软件包交付的&#xff0c;可以很容易地发布和升级。更快速的发布周期对性能提升工作以及改进诸如So…

简单的数学问题 洛谷 P1414 又是毕业季II

题意 给出n个数字&#xff0c;询问从中挑出k个数字&#xff0c;最大可能的公共gcd是多少。 题解 k个数的gcd一定出现至少k次。 我们遍历所有的数并对每个数字求它所有的因子&#xff0c;统计各个因子出现的个数。 给定k时&#xff0c;我们的答案就是所有出现次数>k的因…

【枚举】连续自然数和(jzoj 2102)

连续自然数和 题目大意&#xff1a; 输出一个n&#xff0c;求出所有相加等于n的连续自然数序列 样例输入 10000 样例输出 18 142 297 328 388 412 1998 2002 数据范围限制 10 < M < 2,000,000 解题思路&#xff1a; 这道题的正解的时间复杂度是o(2n)o\left …

nssl1460-逛机房【bfs】

正题 题目大意 nnn次询问&#xff0c;给出一个数xxx&#xff0c;每次可以进行操作 修改其中一个位&#xff0c;去掉前导零删掉其中一个位&#xff0c;去掉前导零 询问最少步骤使得xxx变为一个完全平方数 解题思路 我们可以从完全平方数开始广搜&#xff0c;操作变为 加入一…

将 ASP.NET Core 2.0 项目升级至 ASP.NET Core 2.1 RC 1

微软发布了 .NET Core 2.1 RC 1 &#xff0c;虽然只是 Release Candidate 版&#xff0c;但已经可以在生产环境中使用。NET Core 2.1 RC is supported by Microsoft and can be used in production..NET Core 2.1 的性能大提升早让人垂涎三尺&#xff0c;看到这个消息后&#x…

洛谷P1169 树上分组背包

题解 第一次写树上分组背包的题目。 什么是分组背包&#xff1f; 分组背包就是将物品进行分组每组内部只能选择一类物品。 for(int i 1;i < N;i){for(int j 0;j < V;j){for(int k 0;k < item[I];k){dp[i][j] max(dp[i][j],dp[i-1][j-v[i][k]]w[i][k]); }} …

【dfs】简单游戏(jzoj 2121)

简单游戏 题目大意 原本有n个数字&#xff0c;第1,2个相加&#xff0c;第2&#xff0c;3个相加……第n-1,n个相加&#xff0c;由此得出一个长度为n-1的新序列&#xff0c;然后不停重复&#xff0c;最后得出一个t&#xff0c;现在给出一开始的n和t求符合的序列&#xff08;字典…

nssl1459-空间简单度【扫描线,线段树】

正题 题目大意 nnn个点的一颗树&#xff0c;合法路径定义为一条路径上每个点的编号相差大于KKK。求合法路径数 解题思路 首先我们可以求不合法的路径数&#xff0c;这样我们就有了K∗nK*nK∗n个不合法&#xff08;即不能在同一个路径上&#xff09;的点对。 然后这题就和之前…

ASP.NET Core Identity Hands On(2)——注册、登录、Claim

上一篇文章&#xff08;ASP.NET Core Identity Hands On&#xff08;1&#xff09;——Identity 初次体验&#xff09;中&#xff0c;我们初识了Identity&#xff0c;并且详细分析了AspNetUsers用户存储表&#xff0c;这篇我们将一起学习Identity 默认生成的样板代码的注册与登…