首页 > 其他分享 >[ABC207F] Tree Patrolling 题解

[ABC207F] Tree Patrolling 题解

时间:2023-10-19 09:58:24浏览次数:42  
标签:覆盖 int 题解 Patrolling ABC207F Tree dfs

[ABC207F] Tree Patrolling

弱智 DP 题,设 \(f(i,j,0/1/2)\) 表示在点 \(i\),子树中有 \(j\) 个点被覆盖,且 \(i\) 点自身状态是未被覆盖/被自身覆盖/被某个儿子覆盖,然后树上背包更新就行了。

代码:

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int mod=1e9+7;
const int N=2e3+100;
int n,x,y;
int f[N][N][3],g[N][3],sz[N];
vector<int> v[N];
void dfs(int x,int fa){
    f[x][0][0]=1;
    f[x][1][1]=1;
    sz[x]=1;
    for(auto y:v[x])if(y!=fa){
        dfs(y,x);
        for(int i=0;i<=sz[x];i++){
			for(int j=0;j<=sz[y];j++){
			    (g[i+j][0]+=f[x][i][0]*f[y][j][0]%mod)%=mod;
			    (g[i+j+1][2]+=f[x][i][0]*f[y][j][1]%mod)%=mod;
			    (g[i+j][0]+=f[x][i][0]*f[y][j][2]%mod)%=mod;
			    (g[i+j+1][1]+=f[x][i][1]*f[y][j][0]%mod)%=mod;
			    (g[i+j][1]+=f[x][i][1]*f[y][j][1]%mod)%=mod;
			    (g[i+j][1]+=f[x][i][1]*f[y][j][2]%mod)%=mod;
			    (g[i+j][2]+=f[x][i][2]*f[y][j][0]%mod)%=mod;
			    (g[i+j][2]+=f[x][i][2]*f[y][j][1]%mod)%=mod;
			    (g[i+j][2]+=f[x][i][2]*f[y][j][2]%mod)%=mod;
			}
		}
        sz[x]+=sz[y];
        for(int i=0;i<=sz[x];i++){
			for(int j=0;j<3;j++){
				f[x][i][j]=g[i][j];
				g[i][j]=0;
			}
		}
    }
}
signed main(){
	ios::sync_with_stdio(false);
	cin.tie(0);cout.tie(0);
    cin>>n;
    for(int i=1;i<n;i++){
		cin>>x>>y;
		v[x].push_back(y);
		v[y].push_back(x);
	}
    dfs(1,0);
    for(int i=0;i<=n;i++){
        int res=0;
        for(int j=0;j<3;j++) (res+=f[1][i][j])%=mod;
        cout<<res<<'\n';
    }
    return 0;
}

标签:覆盖,int,题解,Patrolling,ABC207F,Tree,dfs
From: https://www.cnblogs.com/xuantianhao/p/17773996.html

相关文章

  • CF1542E2 Abnormal Permutation Pairs (hard version) 题解
    AbnormalPermutationPairs(hardversion)两个限制:字典序小、逆序对大,一个显然的想法就是确保一对关系,统计另一对关系。确保哪一对呢?我们想了想,决定确保字典序小,因为字典序是可以贪心的。具体而言,我们考虑两个排列自第\(i\)位开始出现了不同。这样子,我们便将两个排列各自划......
  • AT_tdpc_tree 木 题解
    木弱智DP题,直接设\(f_i\)表示\(i\)子树内染色的方案数,然后每次合并一个点与它的儿子即可(具体而言,因为儿子间独立,所以方案数就是二项式系数)。需要注意的是因为第一条边可以在任意位置,所以要以每个点为根各DP一次。但是这样每条边会被算两次,所以乘以2的逆元即可。时间......
  • [ARC072E] Alice in linear land 题解
    [ARC072E]Aliceinlinearland首先,一个trivial的想法是记\(f_i\)表示第\(i\)步前离终点的距离,于是\(f_i=\min\Big(f_{j-1},|f_{j-1}-d_i|\Big)\)。然后,我们设\(f_i'\)表示在修改第\(i\)步后,此时离终点的距离。明显,\(f_i'\)可以为任意不大于\(f_i\)的值,因为此时......
  • CF568E Longest Increasing Subsequence 题解
    LongestIncreasingSubsequenceLIS问题有两种主流\(O(n\logn)\)解法,最常见的树状数组法,以及不那么常见的二分法。然后考虑本题,发现一个神奇的思路就是求出LIS后倒序复原出数组。进一步思考后发现,因为本题是LIS(LongestIncreasingSubsequence)而非LNDS(LongestNon-Decr......
  • [AGC046D] Secret Passage 题解
    SecretPassage稍微观察一下就能发现,任一时刻,我们剩下的东西必然是一段定死了的后缀,加上一些可以任意塞位置的0与1。考虑任意一个由上述时刻生成的串,就会发现它与该后缀的最长公共子序列长度即为后缀长度,且还剩余一些0与1。于是考虑模拟最长公共子序列的过程。设\(g_{i,j......
  • Atcoder Beginner Contest 324 G Generate Arrays 题解-Treap
    为了更好的阅读体验,请点击这里题目链接套上平衡树板子就能做的很快的题,然后因为是指针存树,因此交换只需要把序列大小较小的挨个拿出来插到相应的地方即可。复杂度\(O(N\log^2N)\)。但是一定要记住不可以直接使用std::swap交换包含带有指针的类的实例(如代码中的Treap类)!......
  • 精选题解汇总
    Part1比赛题解CF1873CF1203CF1234CF1249Part2难题题解P1124P6346P2198P7974P4814......
  • P1124 题解
    题目大意一个长度为\(n\)的字符串\(S\),进行以下操作。假设\(s\)为acbdef,每一次将首字母移至末尾,得到\(6\)个字符串:acbdefcbdefabdefacdefacbefacbdfacbde将每个字符串的首字母排序:acbdefbdefaccbdefadefacbefacbdfacbde每个字符串的末尾连在一起为fcab......
  • Linux 环境下(Ubuntu)webbench的安装问题解决与使用
    webbench最多可以模拟3万个并发连接去测试网站的负载能力。并发能力比较高,可以测试https及动态静态页面。适合中小型网站测试承受能力。原理:父进程fork若干个子进程,每个子进程在用户要求时间或默认的时间内对目标web循环发出实际访问请求,父子进程通过管道进行通信,子进程通过......
  • P6346 题解
    题目大意如果\(\texttt{Kevin}\)想和第\(i\)个人交朋友,要么需要认识\(a_i\)个人,要么付出\(b_i\)的代价,他让你使\(\texttt{Kevin}\)与所有的人交朋友。解题思路如果想水到\(15\)分,也就是所有\(b_i\)都等于\(1\)的情况,那我们可以直接排个序,然后遍历一下每一个人,......