LuoguP7043 「MCOI-03」村国 题解
Content
有 \(T\) 组询问,每组询问给定一个有 \(n\) 个节点的数,编号为 \(1\sim n\),每个节点一开始都有权值 \(a_i\)。现有 \(m\) 次操作,每次操作选择树上所有节点中权值最大的一个点(如果有多个选择编号最小的),然后将所有和这个点在树上直接相连的点的权值加 \(1\)。求 \(m\) 次操作以后权值最大的点的编号(如果有多个输出编号最小的)。
数据范围:\(1\leqslant n\leqslant 2\times 10^6,1\leqslant m\leqslant 10^{18},1\leqslant a_i\leqslant 2^{31}-1,1\leqslant T\leqslant 10\)。
Solution
比较具有启发性的题目。
我们先把 \(30\) 分的暴力(本人亲测)写完以后,看能不能找到一些规律。
我们接下来以这个图为例来找一下规律,下图是一个拥有 \(12\) 个节点的树,其中每个节点旁边红色的数字代表着它的权值。(图画得可能不是太好,请见谅)

你也可以直接复制下面的对应数据来 \(\texttt{debug}\) 一下:
1
12 x //这里的 x 可以变成任何数
7 2 5 3 3 10 1 6 5 5 6 8
1 2
1 3
1 4
3 5
3 6
6 8
6 9
4 7
4 10
10 11
11 12
我们来模拟一下每次操作:
第一次,选择权值最大的节点 \(6\),然后让与之直接相连的每个节点的权值增加 \(1\),这样,与之直接相连的节点 \(3,8,9\) 的权值分别变成了 \(6,7,6\)。
第二次,第三次,第四次操作都是选择权值最大的节点 \(6\),就不再赘述了。第四次操作完成以后,节点 \(3,8,9\) 的权值分别变成了 \(9,10,9\)。
第五次,选择权值最大的节点,这是我们发现这样的节点有 \(2\) 个,分别是 \(6\) 和 \(8\),然而由于 \(6<8\),所以我们还是选择节点 \(6\),然后让与之直接相连的每个节点的权值增加 \(1\),这样,与之直接相连的节点 \(3,8,9\) 的权值分别变成了 \(10,11,10\)。
第六次,选择权值最大的节点 \(8\),然后让与之直接相连的每个节点的权值增加 \(1\),与之相连的节点 \(6\) 的权值变成了 \(11\)。
第七次,选择权值最大的节点,这是我们发现这样的节点有 \(2\) 个,分别是 \(6\) 和 \(8\),然而由于 \(6<8\),所以我们还是选择节点 \(6\),然后让与之直接相连的每个节点的权值增加 \(1\),这样,与之直接相连的节点 \(3,8,9\) 的权值分别变成了 \(11,12,11\)。
第八次,选择权值最大的节点 \(8\),然后让与之直接相连的每个节点的权值增加 \(1\),与之相连的节点 \(6\) 的权值变成了 \(12\)。
……
继续这样推下去的话你就能够发现,我们后面所选择的节点一定会在 \(6,8\) 之间反复循环,而这两个点又分别是一开始权值最大的点中编号最小的点和与之直接相连的节点中权值最大的点中编号最小的点。所以,我们可以得到以下思路:
- 记录下来所有与一开始权值最大的点中编号最小的点直接相连的所有点并取当中权值最大的点中编号最小的点。设我们选出来的点的编号分别是 \(k,k'\)。
- 如果 \(a_k-a_{k'}>m\),那么我们的节点 \(k\) 肯定是最后权值最大的点。
- 否则,由于最后的答案肯定在两个点之间反复横跳,我们只需要判断一下 \(m-(a_k-a_{k'})\) 的奇偶性即可。如果是奇数,那么答案肯定就是这两个点当中编号更大的,否则肯定就是这两个点当中编号更小的。这里请读者自己思考。
而且我们惊奇地发现,这个做法成功的越过了全网大部分人跳进去的 \(n=1\) 的坑,所以这个做法从某种意义上来讲是很优越的。
Code
int t, n, a[2000007], num[2000007];
long long m;
int main() {
//This program is written by Eason_AC
scanf("%d", &t);
while(t--) {
memset(num, 0, sizeof(num));
int ans = 0;
scanf("%d%lld", &n, &m);
for(int i = 1; i <= n; ++i) {
scanf("%d", &a[i]);
if((a[i] > a[ans]) || (a[i] == a[ans] && ans > i)) ans = i;
}
for(int i = 1; i < n; ++i) {
int x, y;
scanf("%d%d", &x, &y);
if(x == ans) num[++num[0]] = y;
else if(y == ans) num[++num[0]] = x;
}
if(!num[0]) {printf("%d\n", ans); continue;}
int kk = 1;
for(int i = 1; i <= num[0]; ++i)
if(a[num[i]] > a[num[kk]]) kk = i;
if(a[ans] - a[num[kk]] > m) printf("%d\n", ans);
else if((m - (a[ans] - a[num[kk]])) % 2) printf("%d\n", max(num[kk], ans));
else printf("%d\n", min(num[kk], ans));
}
return 0;
}
LuoguP7043 「MCOI-03」村国 题解的更多相关文章
- 「MCOI-03」村国题解
第二篇题解! 可能是退役之前的最后一篇题解了 (好像总共都只写了两篇) 不说了,讲题: 题面 题意: 有T个数据 有一颗树(保证所有的的节点都是相连的),有n个节点,每个节点都有相应的权值与序号,现在 ...
- LuoguP7127 「RdOI R1」一次函数(function) 题解
Content 设 \(S_k\) 为直线 \(f(x)=kx+k-1\),直线 \(f(x)=(k+1)x+k\) 与 \(x\) 轴围成的三角形的面积.现在给出 \(t\) 组询问,每组询问给定一 ...
- LOJ #2541. 「PKUWC 2018」猎人杀(容斥 , 期望dp , NTT优化)
题意 LOJ #2541. 「PKUWC 2018」猎人杀 题解 一道及其巧妙的题 , 参考了一下这位大佬的博客 ... 令 \(\displaystyle A = \sum_{i=1}^{n} w_ ...
- LOJ #2540. 「PKUWC 2018」随机算法(概率dp)
题意 LOJ #2540. 「PKUWC 2018」随机算法 题解 朴素的就是 \(O(n3^n)\) dp 写了一下有 \(50pts\) ... 大概就是每个点有三个状态 , 考虑了但不在独立集中 ...
- 「GXOI / GZOI2019」简要题解
「GXOI / GZOI2019」简要题解 LOJ#3083. 「GXOI / GZOI2019」与或和 https://loj.ac/problem/3083 题意:求一个矩阵的所有子矩阵的与和 和 ...
- 【题解】#6622. 「THUPC 2019」找树 / findtree(Matrix Tree+FWT)
[题解]#6622. 「THUPC 2019」找树 / findtree(Matrix Tree+FWT) 之前做这道题不理解,有一点走火入魔了,甚至想要一本近世代数来看,然后通过人类智慧思考后发现, ...
- 「POJ 3666」Making the Grade 题解(两种做法)
0前言 感谢yxy童鞋的dp及暴力做法! 1 算法标签 优先队列.dp动态规划+滚动数组优化 2 题目难度 提高/提高+ CF rating:2300 3 题面 「POJ 3666」Making th ...
- FileUpload控件「批次上传 / 多档案同时上传」的范例--以「流水号」产生「变量名称」
原文出處 http://www.dotblogs.com.tw/mis2000lab/archive/2013/08/19/multiple_fileupload_asp_net_20130819. ...
- LOJ #2542. 「PKUWC 2018」随机游走(最值反演 + 树上期望dp + FMT)
写在这道题前面 : 网上的一些题解都不讲那个系数是怎么推得真的不良心 TAT (不是每个人都有那么厉害啊 , 我好菜啊) 而且 LOJ 过的代码千篇一律 ... 那个系数根本看不出来是什么啊 TAT ...
随机推荐
- Go语言核心36讲(Go语言实战与应用十六)--学习笔记
38 | bytes包与字节串操作(上) 前导内容: bytes.Buffer基础知识 strings包和bytes包可以说是一对孪生兄弟,它们在 API 方面非常的相似.单从它们提供的函数的数量和功 ...
- Flink 是如何统一批流引擎的
关注公众号:大数据技术派,回复"资料",领取1000G资料. 本文首发于我的个人博客:Flink 是如何统一批流引擎的 2015 年,Flink 的作者就写了 Apache Fli ...
- python网络自动化运维之telnetlib实验(EVE-NG+pycharm)
运行环境: 物理机:win10 1903 网络设备:EVE-NG模拟器上运行思科三层路由器 网络设备OS版本:cisco ios(versions 15.6) python环境:pycharm 3.3 ...
- Codeforces 497E - Subsequences Return(矩阵乘法)
Codeforces 题目传送门 & 洛谷题目传送门 一道还算不错的矩乘 tea 罢,不过做过类似的题应该就比较套路了-- 首先考虑对于一个固定的序列 \(\{a\}\) 怎样求其本质不同的序 ...
- springcloud - alibaba快速上手 - 更新完毕
1.简单对比一下springcloud与springcloud-alibaba 2.准备知识 官网:https://nacos.io/zh-cn/ 查看cloud和springboot的对应关系 ht ...
- 对于vue项目更新迭代导致上传至服务器后出现Loading chunk {n} failed和Unexpected token <的解决方式
相信大家对于vue项目的维护与更新中会遇见很多问题,其中有两种情况最为常见. 一种是Loading chunk {n} failed,这种情况出现的原因是vue页面更新上传至服务器后,由于vue默认打 ...
- 实时数仓(二):DWD层-数据处理
目录 实时数仓(二):DWD层-数据处理 1.数据源 2.用户行为日志 2.1开发环境搭建 1)包结构 2)pom.xml 3)MykafkaUtil.java 4)log4j.properties ...
- Spark 广播变量和累加器
Spark 的一个核心功能是创建两种特殊类型的变量:广播变量和累加器 广播变量(groadcast varible)为只读变量,它有运行SparkContext的驱动程序创建后发送给参与计算的节点.对 ...
- 答应我,这次必须搞懂!痛点难点Promise。(小点心async/await,基于Promise的更优方案)
Promise 出现的原因 在 Promise 出现以前,我们处理一个异步网络请求,大概是这样: // 请求 代表 一个异步网络调用. // 请求结果 代表网络请求的响应. 请求1(function( ...
- windows Visual Studio 上安装 CUDA【转载】
原文 : http://blog.csdn.net/augusdi/article/details/12527497 前提安装: Visual Studio 2012 Visual Assist X ...