传送门
先考虑什么时候不合法。
第一是考虑任意两个特殊点的权值的奇偶性是否满足条件。
第二是考虑每个点的取值范围是否合法。
如果上述条件都满足的话就可以随便构造出一组解。
代码:
#include<bits/stdc++.h>
#define N 100005
#define inf 0x3f3f3f3f
using namespace std;
inline int read(){
int ans=0;
char ch=getchar();
while(!isdigit(ch))ch=getchar();
while(isdigit(ch))ans=(ans<<3)+(ans<<1)+(ch^48),ch=getchar();
return ans;
}
int n,k,first[N],cnt,fa[N],val[N],low[N],high[N],ans[N],rt;
bool is[N];
struct edge{
int v,next;}e[N<<1];
inline