首页 > 其他分享 >题解【CF1702G2 Passable Paths (hard version)】

题解【CF1702G2 Passable Paths (hard version)】

时间:2022-09-08 09:00:36浏览次数:110  
标签:Paths par return int 题解 hard else read MAXN

题目传送门

考虑建立虚树然后再上面搞树形 DP。

于是这道题就变成分讨题。

设 \(f_i\) 表示 \(i\) 子树内的答案。若 \(f_i=1\),表示 \(i\) 子树内的特殊点可以被一条链覆盖,且 \(i\) 可以作为链的开头。若 \(f_{i}=1\),表示 \(i\) 子树内的点可以被一条链覆盖,但 \(i\) 不能作为链的开头。\(f_{i}=-1\) 表示 \(i\) 子树内的点不能被一条链覆盖。

设 \(x\) 表示 \(i\) 儿子中 \(f_{j}=1\) 的数量,\(y\) 表示 \(i\) 的儿子中 \(f_{j}=0\) 的数量。如果存在一个孩子 \(j\) 使得 \(f_{j}=-1\),那么 \(f_{i}=-1\)。

  • 如果 \(x+y\ge 3\),不存在一条链同时跨过三个子树,\(f_{i}=-1\)。

  • 如果 \(x=1\) 且 \(y=1\),同样 \(f_{i}=-1\)。

  • 如果 \(x=2\) 且 \(y=0\),那么两个儿子可以拼在一起,但 \(i\) 不能作为链头,\(f_{i}=0\)。

  • 如果 \(y=2\) 且 \(y=0\),那么也不存在这样一条链,\(f_i=0\)。

  • 如果 \(x=1\) 且 \(y=0\),那么 \(i\) 可以作为链头,\(f_i=1\)。

  • 如果 \(x=0\) 且 \(y=1\),那么如果 \(i\) 是特殊点,显然不可能构成一条链,\(f_{i}=0\);否则答案可以继承,\(f_i=0\)。

  • 如果 \(x=0\) 且 \(y=0\),根据虚树的性质,\(i\) 肯定是叶子节点且是特殊点。那么 \(f_i=1\)。

注意虚树写法的不同可能会导致空间需要多开一点。

代码:

const int MAXN(4e5+10);

int n,m;
struct E{int to,nxt;};
E edge[MAXN<<1];
int head[MAXN],tot;
vector<int>G[MAXN];
int dep[MAXN],par[MAXN][23],dfn[MAXN],t,vir[MAXN],num,rt;
int q[MAXN],cnt,in[MAXN],f[MAXN];
bool flag[MAXN];
int b[MAXN];

inline void add_edge(int u,int v)
{
	edge[++tot].nxt=head[u];
	head[u]=tot;
	edge[tot].to=v;
	return;
}

inline void dfs1(int u,int fa)
{
	par[u][0]=fa,dep[u]=dep[fa]+1,dfn[u]=++t;
	rep(i,1,22) par[u][i]=par[par[u][i-1]][i-1];
	gra(i,u)
	{
		E e=edge[i];
		if(e.to!=fa) dfs1(e.to,u); 
	}
	return;
}

inline int LCA(int x,int y)
{
	if(dep[x]<dep[y]) Swap(x,y);
	rev(k,22,0) if(dep[par[x][k]]>=dep[y]) x=par[x][k];
	if(x==y) return x;
	rev(k,22,0) if(par[x][k]!=par[y][k]) x=par[x][k],y=par[y][k];
	return par[x][0];	
}

inline void init_()
{
	rep(i,1,cnt) flag[q[i]]=false,G[q[i]].clear(),f[q[i]]=0,in[q[i]]=0;
	cnt=0;
	return;
}

inline bool cmp(int x,int y){return dfn[x]<dfn[y];}

inline void build(int k)
{
	num=k;
	sort(vir+1,vir+1+k,cmp);
	rep(i,2,k)
	{
		int g=LCA(vir[i],vir[i-1]);
		if(g!=vir[i]&&g!=vir[i-1]) vir[++num]=g;
	}
	sort(vir+1,vir+1+num);
	num=unique(vir+1,vir+1+num)-vir-1;
	sort(vir+1,vir+1+num,cmp);
	q[++cnt]=vir[1];
	rep(i,2,num)
	{
		int g=LCA(vir[i],vir[i-1]);
		G[g].push_back(vir[i]);
		++in[vir[i]];
		q[++cnt]=g,q[++cnt]=vir[i];
	}
	rep(i,1,cnt)
	{
		int u=q[i];
		if(in[u]==0){rt=u;break;}
	}
	return;
}

inline void dfs(int u)
{
	int tot1=0,tot2=0;
	rep(i,0,(int)G[u].size()-1)
	{
		int v=G[u].at(i);
		dfs(v);
		if(f[v]==-1)
		{
			f[u]=-1;
			return;
		}
		if(f[v]) ++tot1;
		else ++tot2;
	}
	if(tot1==0&&tot2==0) f[u]=1;
	else if(tot1+tot2>=3) f[u]=-1;
	else if(tot1==2) f[u]=0;
	else if(tot2==2) f[u]=-1;
	else if(tot1==1&&tot2==1) f[u]=-1;
	else if(tot1==1) f[u]=1;
	else if(tot2==1)
	{
		if(flag[u]) f[u]=-1;
		else f[u]=0;
	}
	return; 
}

int main()
{
//	freopen("read.txt","r",stdin);
	n=read();
	rep(i,2,n)
	{
		int u=read(),v=read();
		add_edge(u,v),add_edge(v,u);
	}
	dfs1(1,0);
	m=read();
	while(m--)
	{
		int k=read();
		rep(i,1,k) vir[i]=read(),b[i]=vir[i],flag[vir[i]]=true;
		build(k);
		dfs(rt);
		if(f[rt]==-1) puts("NO");
		else puts("YES");
		init_();
		rep(i,1,k) flag[b[i]]=false;
	}
	return 0;
}
/*
Date : 2022/9/8
Author : UperFicial
Start coding at : 7:37
finish debugging at : 8:39
*/

标签:Paths,par,return,int,题解,hard,else,read,MAXN
From: https://www.cnblogs.com/UperFicial/p/16668255.html

相关文章

  • CF1718D 题解
    设\(k\)为\(a\)中的空位数量。首先咱们转化这个“相似”的条件,发现它其实是说,笛卡尔树的结构相同。那么我们把p建笛卡尔树然后把a的数往上填。如果此时有上面小于下......
  • Android安卓浏览器视频层级永远顶层问题解决方案
    在安卓手机上,使用video播放视频有个问题,video控件层级会永远在顶层,不利于视频互动H5开发,而IOS手机上不会有此问题。腾讯给出了如下解决方案:<videosrc="http://xxx.mp4......
  • AtCoder Beginner Contest 267 题解
    只会\(A\simG\)主观难度:\(A<B<C<E<D<F<G<Ex\)A-Saturday分别对周一到周五判断即可。#include<bits/stdc++.h>usingnamespacestd;inlineintread(){int......
  • ShardingSphere-JDBC
    概述ApacheShardingSphere‐JDBC可以通过Java,YAML,Spring命名空间和SpringBootStarter这4种方式进行配置,开发者可根据场景选择适合的配置方式。本文章主要讲解数......
  • CF1305F Kuroni and the Punishment 题解
    一道比较简单的题,我居然调了这么久。思路看一眼这个题,发现好像没有什么思路。考虑来用一些巧妙的手法,比如随机化。首先证明一个结论,至少有一半的数只会被操作一次或者......
  • CF1715E Long Way Home 题解
    CF1715E题解题意一个带边权无向图,可以沿着边走,需要边权的花费或从任意点\(u\)飞到\(v\),需要\((u-v)^2\)的花费。求从点\(1\)到所有\(i\)的最少花费。最多飞\(......
  • CF1515E Phoenix and Computers 题解
    感觉这样的\(\text{dp}\)题还比较多,思路都比较的神奇。个人感觉比较像区间\(\text{dp}\)的一类变种。但又和区间\(\text{dp}\)的维护方式极不一样。对于此类\(\t......
  • P5999 [CEOI2016] kangaroo 题解
    感觉这样的\(\text{dp}\)题还比较多,思路都比较的神奇。个人感觉比较像区间\(\text{dp}\)的一类变种。但又和区间\(\text{dp}\)的维护方式极不一样。对于此类\(\t......
  • MySQL5.7完整安装教程及相关问题解决
    1 下载安装1.1下载直接官网下载https://www.mysql.com/①拉倒最下面,点community server②选择之前的版本③选5.7,通过压缩包来安装,点download1.2解压安装①下......
  • CF222C Reducing Fractions 题解
    虽然是朴素的筛法,但是跑的比希儿的Pollard-rho快。\(\mathcalO(n\sqrtn)\)的质因数分解是不行的,Pollard-rho的码量也过于麻烦,直接在线性筛里筛出每个数的最小质因子......