【树形DP+换根思想】2022牛客多校加赛 H

登录---专业IT笔试面试备考平台_牛客网

题意:

思路:

这个虽然是树形DP,却用了换根的思想....

首先,后缀0的个数可以转化成min(cnt2,cnt5),其中cnt2为2的因子个数,cnt5为5的因子个数

然后进行DP

设dp[u][0/1]为,在除了u这棵子树中,2/5的因子个数

为什么要这么设计,我们发现,如果计算的结点是在子树里面的,那么lca就是u,子树的贡献直接就是sz[u]*cnt[u][0/1]

但是在这棵子树之外的贡献不能这么求,因此需要额外设计

然后转移就很简单:

dp[v][j]=dp[u][j]+(sz[u]-sz[v])*cnt[u][j]

最后统计贡献的时候加上子树部分的贡献,取min(cnt2,cnt5)就好了

Code:

cpp 复制代码
#include <bits/stdc++.h>

#define int long long

using namespace std;

const int mxn=2e5+10;
const int mxe=1e6+10;
const int mxv=1e6+10;
const int mod=998244353;
const int Inf=1e18;

vector<int> G[mxn];

int N,Q;
int u,v,x;
int sz[mxn];
int dp[mxn][2],cnt[mxn][2];

void init(){
    for(int i=1;i<=N;i++){
        if(i%2==0){
            int t=i,s=0;
            while(t%2==0) t/=2,s++;
            cnt[i][0]=s;
        }
        if(i%5==0){
            int t=i,s=0;
            while(t%5==0) t/=5,s++;
            cnt[i][1]=s;
        }
    }
}
void dfs1(int u,int fa){
    sz[u]=1;
    for(auto v:G[u]){
        if(v==fa) continue;
        dfs1(v,u);
        sz[u]+=sz[v];
    }
}
void dfs2(int u,int fa){
    for(auto v:G[u]){
        if(v==fa) continue;
        for(int j=0;j<=1;j++){
            dp[v][j]=dp[u][j]+(sz[u]-sz[v])*cnt[u][j];
        }
        dfs2(v,u);
    }
}
void solve(){
    cin>>N>>Q;
    init();
    for(int i=1;i<=N-1;i++){
        cin>>u>>v;
        G[u].push_back(v);
        G[v].push_back(u);
    }
    dfs1(1,0);
    dfs2(1,0);
    while(Q--){
        cin>>x;
        int res=1e18;
        for(int j=0;j<=1;j++){
            res=min(res,dp[x][j]+sz[x]*cnt[x][j]);
        }
        cout<<res<<'\n';
    }
}
signed main(){
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	int __=1;//cin>>__;
	while(__--)solve();return 0;
}
相关推荐
郝学胜-神的一滴4 分钟前
GLSL语法详解:从入门到实战
c++·算法·图形渲染
qq_463408426 分钟前
React Native跨平台技术在开源鸿蒙中使用内置的`fetch` API或者第三方库如`axHarmony`来处理网络通信HTTP请求
javascript·算法·react native·react.js·http·开源·harmonyos
蒙奇D索大7 分钟前
【数据结构】考研408 | 散列查找性能剖析:装填因子、冲突策略与优化全攻略
数据结构·考研·算法·哈希算法·改行学it
88号技师9 分钟前
2025年10月一区SCI-中心碰撞优化算法Centered Collision Optimizer-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
zore_c11 分钟前
【数据结构】堆——超详解!!!(包含堆的实现)
c语言·开发语言·数据结构·经验分享·笔记·算法·链表
月明长歌18 分钟前
【码道初阶】【LeetCode387】如何高效找到字符串中第一个不重复的字符?
java·开发语言·数据结构·算法·leetcode·哈希算法
罗湖老棍子19 分钟前
C++ 自定义排序与优先队列运算符重载
数据结构·c++·算法··优先队列·运算符重载
毅炼21 分钟前
hot100打卡——day01
算法
Wang2012201322 分钟前
AI 相关的算法;架构等专有名称总结和介绍
人工智能·算法·架构
良木生香28 分钟前
【数据结构-初阶】二叉树(1)---树的相关概念
c语言·数据结构·算法·蓝桥杯