Problem - 2167F - Codeforces

Problem - 2167F - Codeforces

我们要计算1-n每个点作为根的时候 可以作为k个元素的lca的节点的集合的大小的总和

如果直接计算 明显会很复杂

我们可以考虑贡献发

我们可以得到以下性质:

1.当i的子树的规模大于等于k的时候 i可以作为子树的lca 因此当i的子树之外的点做根的时候 l都可以作为lca 贡献为n-szi

2.当根在i的子树里面的时候 如果n-szi>=k 的话 i里面的所有节点当作根的时候 u刚好满足条件 那么就贡献就是szi

代码如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define int long long
void solve(){
    int n,k;
    cin>>n>>k;
    vector<int>sz(n+1,1);
    vector<vector<int>>e(n+1);
    for(int i=1;i<n;i++){
        int u,v;
        cin>>u>>v;
        e[u].push_back(v);
        e[v].push_back(u);
    }
    auto dfs=[&](auto &dfs,int v,int p)->void {
        for(int u:e[v]){
            if(u!=p){
                dfs(dfs,u,v);
                sz[v]+=sz[u];
            }
        }
    };
    dfs(dfs,1,0);
    int ans=0;
    for(int i=1;i<=n;i++){
        if(n-sz[i]>=k){
            ans+=sz[i];
        }
        if(sz[i]>=k)ans+=n-sz[i];
    }
    cout<<ans+n<<'\n';
}
signed main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    int t;
    cin>>t;
    while(t--)solve();
    return 0;
}
相关推荐
To_OC8 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵12 小时前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC14 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
To_OC1 天前
LC 128 最长连续序列:别上来就排序,O (n) 解法才是这题的灵魂
javascript·算法·leetcode
05Kevin2 天前
lk每日冒险题--数据结构6.27
算法
To_OC2 天前
从一次栈溢出报错说起,我把递归彻底扒明白了
javascript·算法·程序员
千纸鹤安安3 天前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者3 天前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent