【2019.10.7 CCF-CSP-2019模拟赛 T1】树上查询（tree）（思维）

具体

$p_i$为从$i$到根路径上的最小值，考虑一个黑点$y$对于$x$号点的贡献。

$x$的答案就是$min(p_x,t)$

代码

#include<bits/stdc++.h>
#define Tp template<typename Ty>
#define Ts template<typename Ty,typename... Ar>
#define Reg register
#define RI Reg int
#define Con const
#define CI Con int&
#define I inline
#define W while
#define N 1000000
#define Gmin(x,y) (x>(y)&&(x=(y)))
#define min(x,y) ((x)<(y)?(x):(y))
using namespace std;
int n,Qt,ee,lnk[N+5];struct edge {int to,nxt;}e[N<<1];
class FastIO
{
private:
#define FS 100000
#define pc(c) (C==E&&(clear(),0),*C++=c)
#define tn (x<<3)+(x<<1)
#define D isdigit(c=tc())
int T;char c,*A,*B,*C,*E,FI[FS],FO[FS],S[FS];
public:
I FastIO() {A=B=FI,C=FO,E=FO+FS;}
Tp I void read(Ty& x) {x=0;W(!D);W(x=tn+(c&15),D);}
Tp I void write(Ty x) {W(S[++T]=x%10+48,x/=10);W(T) pc(S[T--]);}
Tp I void writeln(Con Ty& x) {write(x),pc('\n');}
I void clear() {fwrite(FO,1,C-FO,stdout),C=FO;}
}F;
class Solver
{
private:
int p[N+5];
I void dfs(CI x,CI lst=0)//初始化p
{
for(RI i=lnk[x];i;i=e[i].nxt) e[i].to^lst&&
(p[e[i].to]=min(p[x],e[i].to),dfs(e[i].to,x),0);
}
public:
I void Solve()
{
}