AGC027F - Grafting

题目大意

一棵树,每次可以把一个之前未被操作过的叶子移到另一个节点上,求最小步数使其变为目标树或判断无解

数据组数T<=20,n<=50

题解

这应该是我做过的最水的F了,虽然赛场上没有标拍基本调不出来

T和n都很小,所以可以乱搞

枚举A树中一个点将其移到另一个点上(或者不变),这样等于把该点给确定下来了

把AB取并得到C树,移到的位置所在C树的连通块之外的点数加上第一步是否移动就是答案

因为如果已经在连通块里的就不必移动,不在的一定要移动

接着判断是否存在合法方案,每次把一个是当前A树叶子且于当前构出的部分B树相连的点拉出来考虑

实现可以用栈,每次把未加入过的且符合条件(A叶子+B相连)的加进去即可

时间复杂度O(Tn^3)

code

#include 
#define fo(a,b,c) for (a=b; a<=c; a++)
#define fd(a,b,c) for (a=b; a>=c; a--)
#define min(a,b) (an)?-1:ans);
	}
	
	fclose(stdin);
	fclose(stdout);
	return 0;
}

你可能感兴趣的:(AGC027F - Grafting)