题目大意
一棵树,每次可以把一个之前未被操作过的叶子移到另一个节点上,求最小步数使其变为目标树或判断无解
数据组数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;
}