首页 > 其他分享 >2023.08.24T3 - brain - solution

2023.08.24T3 - brain - solution

时间:2023-08-26 16:00:40浏览次数:59  
标签:2023.08 24T3 limits sum solution 权值 aligned 变化 边权

brain

Problem

给定一棵以 \(1\) 为根的树,给定树上所有点权与边权。

记 \(d(i, j)\) 表示 \(i\) 到 \(j\) 的路径长度。定义一棵树的权值为:

\[\sum\limits_{i = 1}^{n - 1}\sum\limits_{j = i + 1}^{n}a_{i}a_{j}d(i, j) \]

定义一次对点 \(i\) 的改造操作为:

  • 删掉 \(i\) 与其父节点相连的边,并选择子树 \(i\) 内的一个点 \(x\)(\(x\) 可以为 \(i\) 本身),将 \(x\) 与 \(i\) 的父节点相连,形成一棵新树。

对点 \(i \in [2, n]\),求出对 \(i\) 改造后树权值的最大值。

Solution

求出原树的权值是容易的。

考虑对每个操作计算其 变化量 并取其最值。

对点 \(i\) 进行改造操作,记 \(T_1\) 表示子树 \(i\),\(T_2\) 表示原树去掉 \(T_1\) 后的连通块,考虑对变化量做贡献的只有那些不在同一连通块内的点对 \((p, q)\)。

以下记 \(a_i\) 表示点 \(i\) 的权值,\(s_i\) 表示子树 \(i\) 内的点权和,\(w_i\) 表示 \(i\) 与父节点连边的边权。

对 \(T_1\) 内的任意点 \(x\) 作为新边的端点求出所有上述点对 \((p, q)\) 的代价,以便分析 \(x\) 变化时 这部分变化量的大小。

\[\begin{aligned} \sum\limits_{p \in T_1}\sum\limits_{q \in T_2}a_{p}a_{q}d(p, q) &= \sum\limits_{p \in T_1}\sum\limits_{q \in T_2}a_{p}a_{q}(d(p, x) + d(x, q)) \\ &= \sum\limits_{q \in T_2}a_{q}\sum\limits_{p \in T_1}a_{p}d(p, x) + \sum\limits_{p \in T_1}a_{p}\sum\limits_{q \in T_2}a_{q}d(x, q) \end{aligned} \]

注意 \(x\) 是变量,因此后面的式子是定值,只有前面的 \(\sum\limits_{p \in T_1}a_{p}d(p, x)\) 是关于 \(x\) 变化的。

再强调一遍,这里是对不同的 \(x\) 考察已经重连边后我们指定的点对的贡献值是否变化,而不是固定死 \(x\),考察改造前后的贡献值怎样变化。原题解正是在这里没有想清楚,导致定值与变化的量恰好搞反了,真是害人不浅

那我们不是要算改造前后的变化量吗?是要,没错,但如果你固定死 \(x\) 去考察,你就要枚举 \(x\),而这是时间复杂度不允许的。

但如果你对子树 \(i\) 内的每个 \(x\) 算出改造后的点对贡献值,你只需再减去原贡献值就可以得出变化量,并且你有机会在一个较为优秀的时间复杂度内解决变化量的最值问题。

好,现在考察 \(\sum\limits_{p \in T_1}a_{p}d(p, x)\) 的变化量。

思考重连边对子树 \(i\) 内影响的实质是什么?换根

把 \(d(p, x)\) 拆到边权上进行考虑,发现只有在 \(i\) 到 \(x\) 的路径上的边对变化量做贡献。变化量要从 “增量”(新算 \(p \to x\) 的贡献) 与 “减量”(减掉 \(p \to i\) 的贡献) 分别考虑。具体地,可以如下表示出变化量:

\[\begin{aligned} &\,\,\,\,\,\,\,\, \sum\limits_{j \in Path(i \to x), j \neq i}w_j\times (s_i - s_j) - \sum\limits_{j \in Path(i \to x), j \neq i}w_j \times s_j \\ &= \sum\limits_{j \in Path(i \to x), j \neq i}w_j\times (s_i - 2s_j) \end{aligned} \]

这个 \(Path(i \to x)\) 太难看了,显然可以用前缀和表示。

记 \(l_i\) 表示 \(i \to 1\) 的边权和,\(c_i\) 表示 \(i \to 1\) 路径上 \(s_jw_j\) 之和(这里的所有变量名都和原题解一致)。化简上述变化量:

\[\begin{aligned} \sum\limits_{j \in Path(i \to x), j \neq i}w_j\times (s_i - 2s_j) &= s_i\times (l_x - l_i) - 2(c_x - c_i) \\ &= (s_{i}l_{x} - 2c_{x}) + 2c_i - s_{i}l_{i} \end{aligned} \]

注意转化后括号里面是关于 \(x\) 的一次函数。这是什么?

李超线段树合并。完结撒花。

之后贴个代码。


牢骚:原题面将边权以 “他到他的父亲的边的边权为 \(w_i\)” 的方式给出。

本人以为树的形态改变后,一条边的权值会随着父子关系的变化而变化,遂爆零QWQ。

标签:2023.08,24T3,limits,sum,solution,权值,aligned,变化,边权
From: https://www.cnblogs.com/Schucking-Sattin/p/17658908.html

相关文章

  • python采集京东商品详情页面数据,京东API接口,京东h5st签名(2023.08.20)
    一、原理与分析1、目标页面https://item.jd.com/6515029.html  在chrome中打开,按f12键进入开发者模式,找到商品详情数据接口,如下:2、URL链接:https://api.m.jd.com/?appid=pc-item-soa&functionId=pc_detailpage_wareBusiness&client=pc&clientVersion=1.0.0&t=1692499380806&bod......
  • 2023.08.13百度之星(大失败)
    大失败,哭;放个链接,有空来补:码蹄集(matiji.net)前面两题写的还挺顺手,然后开始写4和6,然后寄了,两个题加起来大概交了十发吧,算法没什么大问题,但是写挂了,都只能过一半的样例,悲;总结:沉淀,提升码力;1记录把每个参数都调成同一个值的代价和把每个参数调成一段连续的数的代价,比较相加最小......
  • IPQ5018|Unlocking Affordable WiFi 6: The Ultimate Solution
    IPQ5018|UnlockingAffordableWiFi6:TheUltimateSolutionIntheeraoflightning-fastconnectivitydemands,findingtheperfectsynergybetweenperformance,efficiency,andcost-effectivenessisparamount.IntroducingtheDR5018-aWiFi6solutionthat......
  • 2023.08.12 codeforces round 893 div2
    年轻人的第四场div2rank:8217solved:2ratingchange:+31newrating:1354A.Buttons题意:给定a,b,c三种按钮的数量,a按钮只能被Anna按,b按钮只能被Katie按,两个人都可以按c按钮,最后没有按钮可以按的人输,Anna先手,问谁是赢家;两个人肯定优先按c按钮,且Anna是先手,只需比较两人能按的按......
  • 2023.08.15 闲话
    《bitset传奇:0.5s过2e10/w》bitset很快,1s可能可以过4e10/w的。冲正解别犹豫,别一道题会正解却先写暴力又写正解。......
  • Day26(2023.08.10)
    行程8:45    到达上海市信息安全测评认证中心(黄浦区陆家浜路1308号)9:00  Windows核查11:30--13:00   吃饭休息13:00 Windows核查17:00      下班   其中lusrmgr.msc      本地用户和组gpedit.msc......
  • Day25(2023.08.09)
    行程8:45    到达上海市信息安全测评认证中心(黄浦区陆家浜路1308号)9:00  Linux核查11:30--13:00   吃饭休息13:00 Linux核查17:00      下班    其中/etc/passwd/etc/hosts.equiv/etc/login.defs/etc......
  • 2023.08.12 codeforces round 892 div2
    年轻人的第三场div2(已完成:ABCDE)rank:1265solved:4ratingchange:+276newrating:1323A.UnitedWeStand题意:给定一个数列a,问是否能分成两个非空的数列b和c,使得c中任意一个数不是b中任意一个数的因子;若x是y的因子则有x<=y;因此不妨将数列的最大值放入c,把剩下的数放入b;注意数列中......
  • 2023.08.08杭电多校第七场
    solved:3/13rank:B.RandomNimGame题意:两个人玩Nim游戏取石子,但是每次选择石子都是随机的,问最后先手获胜的概率;瞎写了几组样例算出来都是1/2,遂大胆猜想:除了每堆石子都只有一个时按石子堆数的奇偶判断先手获胜的概率是1还是0,其余情况先手获胜概率都是1/2;根据题解所说,可以用归纳......
  • 2023.08.10杭电多校第八场
    solved:3rank:C.Congruences题意:对于每组数据给定M个pi和qi,pi为两两不同的质数,N为所有pi的积,问是否存在最小的正整数x使得xpi在模N的意义下与qi同余可以推出xpi在模pi的意义下与qi同余在模N的意义下与qi同余,如果存在输出x,否则输出-1;显然xpi在模N的意义下与qi同余可以......