思维

这道题应该算是一道思维题吧。

首先你要想到,既然这是一棵无根树,就要明智地选择根——以第一个黑点为根(不要像我一样习惯性以\(1\)号点为根,结果直到心态爆炸都没做出来)。

想到这一点,这题就很简单了。

具体

设\(p_i\)为从\(i\)到根路径上的最小值,考虑一个黑点\(y\)对于\(x\)号点的贡献。

显然这一贡献就是将\(x\)的答案向\(y\)到\(LCA(x,y)\)路径上的最小值取\(min\)。

而由于\(LCA(x,y)\)到根路径上的最小值也是\(x\)到根路径上的最小值,肯定会被算在答案中,所以就相当于是向\(y\)到根路径上的最小值,即\(p_y\)取\(min\)。

所以,我们开一个变量\(t\),记录所有黑点\(p\)的最小值。

则\(x\)的答案就是\(min(p_x,t)\)。

代码

  1. #include<bits/stdc++.h>
  2. #define Tp template<typename Ty>
  3. #define Ts template<typename Ty,typename... Ar>
  4. #define Reg register
  5. #define RI Reg int
  6. #define Con const
  7. #define CI Con int&
  8. #define I inline
  9. #define W while
  10. #define N 1000000
  11. #define add(x,y) (e[++ee].nxt=lnk[x],e[lnk[x]=ee].to=y)
  12. #define Gmin(x,y) (x>(y)&&(x=(y)))
  13. #define min(x,y) ((x)<(y)?(x):(y))
  14. using namespace std;
  15. int n,Qt,ee,lnk[N+5];struct edge {int to,nxt;}e[N<<1];
  16. class FastIO
  17. {
  18. private:
  19. #define FS 100000
  20. #define tc() (A==B&&(B=(A=FI)+fread(FI,1,FS,stdin),A==B)?EOF:*A++)
  21. #define pc(c) (C==E&&(clear(),0),*C++=c)
  22. #define tn (x<<3)+(x<<1)
  23. #define D isdigit(c=tc())
  24. int T;char c,*A,*B,*C,*E,FI[FS],FO[FS],S[FS];
  25. public:
  26. I FastIO() {A=B=FI,C=FO,E=FO+FS;}
  27. Tp I void read(Ty& x) {x=0;W(!D);W(x=tn+(c&15),D);}
  28. Ts I void read(Ty& x,Ar&... y) {read(x),read(y...);}
  29. Tp I void write(Ty x) {W(S[++T]=x%10+48,x/=10);W(T) pc(S[T--]);}
  30. Tp I void writeln(Con Ty& x) {write(x),pc('\n');}
  31. I void clear() {fwrite(FO,1,C-FO,stdout),C=FO;}
  32. }F;
  33. class Solver
  34. {
  35. private:
  36. int p[N+5];
  37. I void dfs(CI x,CI lst=0)//初始化p
  38. {
  39. for(RI i=lnk[x];i;i=e[i].nxt) e[i].to^lst&&
  40. (p[e[i].to]=min(p[x],e[i].to),dfs(e[i].to,x),0);
  41. }
  42. public:
  43. I void Solve()
  44. {
  45. RI op,x,t,lst=0;F.read(op,x),--Qt,t=x%n+1,dfs(p[t]=t);//以第一个黑点为根
  46. W(Qt--) F.read(op,x),op==1?Gmin(t,p[(x+lst)%n+1]):(F.writeln(lst=min(t,p[(x+lst)%n+1])),0);//进行操作
  47. }
  48. }S;
  49. int main()
  50. {
  51. freopen("tree.in","r",stdin),freopen("tree.out","w",stdout);
  52. RI i,x,y;for(F.read(n,Qt),i=1;i^n;++i) F.read(x,y),add(x,y),add(y,x);
  53. return S.Solve(),F.clear(),0;
  54. }

【2019.10.7 CCF-CSP-2019模拟赛 T1】树上查询(tree)(思维)的更多相关文章

  1. 【洛谷比赛】[LnOI2019]长脖子鹿省选模拟赛 T1 题解

    今天是[LnOI2019]长脖子鹿省选模拟赛的时间,小编表示考的不怎么样,改了半天也只会改第一题,那也先呈上题解吧. T1:P5248 [LnOI2019SP]快速多项式变换(FPT) 一看这题就很手 ...

  2. 20180610模拟赛T1——脱离地牢

    Description 在一个神秘的国度里,年轻的王子Paris与美丽的公主Helen在一起过着幸福的生活.他们都随身带有一块带磁性的阴阳魔法石,身居地狱的魔王Satan早就想着得到这两块石头了,只要 ...

  3. 2019.10.22 校内CSP%你赛

    我太难了 先说好没有代码T1 题目大意: 给定一些形如|ax+b|的式子,求最小的x使得它们的和最小. 算法一: 大家知道零点分段法 对于这n个式子我们有n+1个取值范围 使得展开这n个式子得到的新式 ...

  4. 2019/8/27 Test(luogu 五月天模拟赛)

    \(2019/8/27\)大考 \(\color{#ff0808}{\text{初二诀别赛(SAD)}}\) 题目名称 链接 寿司 \(BSOJ5111\) 秀秀的森林 \(BSOJ5125\) 分组 ...

  5. 2019.2.25 模拟赛T1【集训队作业2018】小Z的礼物

    T1: [集训队作业2018]小Z的礼物 我们发现我们要求的是覆盖所有集合里的元素的期望时间. 设\(t_{i,j}\)表示第一次覆盖第i行第j列的格子的时间,我们要求的是\(max\{ALL\}\) ...

  6. 【2019.8.15 慈溪模拟赛 T1】插头(plugin)(二分+贪心)

    二分 首先,可以发现,最后的答案显然满足可二分性,因此我们可以二分答案. 然后,我们只要贪心,就可以验证了. 贪心 不难发现,肯定会优先选择能提供更多插座的排插,且在确定充电器个数的情况下,肯定选择能 ...

  7. 【2019.7.20 NOIP模拟赛 T1】A(A)(暴搜)

    打表+暴搜 这道题目,显然是需要打表的,不过打表的方式可以有很多. 我是打了两个表,分别表示每个数字所需的火柴棒根数以及从一个数字到另一个数字,除了需要去除或加入的火柴棒外,至少需要几根火柴棒. 然后 ...

  8. 【2019.7.24 NOIP模拟赛 T1】道路建设(road)(水题)

    原题与此题 原题是一道神仙不可做题,两者区别在于,原题不能有重边和自环. 然而,这题可以有重边... 于是这题就变成了一道大水题. 此题的解法 考虑如何构造. 对于\(n\le10^4\)的情况: 对 ...

  9. 【2019.7.16 NOIP模拟赛 T1】洗牌(shuffle)(找环)

    找环 考虑每次洗牌其实是一次置换的过程,而这样必然就会有循环出现. 因此我们直接通过枚举找出每一个循环,询问时只要找到环上对应的位置就可以了. 貌似比我比赛时被卡成\(30\)分的倍增简单多了? 代码 ...

随机推荐

  1. iOS正则表达式解决实际问题

    问题:上海市徐汇区桂林路158号1202室 字符串长度不固定,数字长度也不固定.截取第二组数字. 方法一:[正则表达式] NSString * str = @"上海市徐汇区桂林路158号12 ...

  2. Android View的background和padding

    版权声明:本文为xing_star原创文章,转载请注明出处! 本文同步自http://javaexception.com/archives/181 最近在做一个需求,是对im聊天消息设置气泡背景,之前 ...

  3. python中 遇到的读取坑2.7和3.6版本的问题

    2.7读取,需要使用io.open 3.x使用open 使用io.open的时候路径需要使用\\ 目前io.open的文件名不能为中文

  4. django-xadmin自定义widget插件(自定义详情页字段的显示样式)

    有时候我们想要修改xadmin详情页字段的显示方式,比如django默认的ImageField在后台显示的是image的url,我们更希望看到image的缩略图:再比如django将多对多字段显示为多 ...

  5. picoCTF2018记录

    近期准备参加CTF 一头雾水 开始练练手 https://2018game.picoctf.com/  这个网站挺适合新手的(据说面向高中生?? 惭愧惭愧) 前面几个比较简单 就从 Resources ...

  6. MATLAB小函数:将列向量转化为0-1矩阵

    MATLAB小函数:将列向量转化为0-1矩阵 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 将列向量转化为0-1矩阵,例如 A = 1 2 1 5 3 ...

  7. .net core 反射的介绍与使用

      1. 概述反射 通过反射可以提供类型信息,从而使得我们开发人员在运行时能够利用这些信息构造和使用对象. 反射机制允许程序在执行过程中动态地添加各种功能.   2. Type类的介绍  是BCL(基 ...

  8. 在python操作数据库中游标的使用方法

    cursor就是一个Cursor对象,这个cursor是一个实现了迭代器(def__iter__())和生成器(yield)的MySQLdb对象,这个时候cursor中还没有数据,只有等到fetcho ...

  9. golang中,new和make的区别

    在golang中,make和new都是分配内存的,但是它们之间还是有些区别的,只有理解了它们之间的不同,才能在合适的场合使用. 简单来说,new只是分配内存,不初始化内存: 而make即分配又初始化内 ...

  10. Java 的 IO 流

    接着上一篇的 “Java 的 File 类” 的随笔,在File类的基础上,我们就走进Java的IO流吧. 流的概念和作用 流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象.即数据在 ...