Problem - 2167F - Codeforces

Problem - 2167F - Codeforces

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

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

我们可以考虑贡献发

我们可以得到以下性质:

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

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

代码如下:

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;
}
相关推荐
MORE_772 小时前
leecode100-跳跃游戏-贪心算法
算法·游戏·贪心算法
机器学习之心2 小时前
基于GSWOA-SVM三种策略改进鲸鱼算法优化支持向量机的数据多变量时间序列预测,Matlab代码
算法·支持向量机·matlab·优化支持向量机·gswoa-svm·三种策略改进鲸鱼算法
旖-旎2 小时前
前缀和(和为K的子数组)(5)
c++·算法·leetcode·前缀和·哈希算法·散列表
进击的荆棘2 小时前
优选算法——链表
数据结构·算法·链表·stl
凌波粒2 小时前
LeetCode--203.移除链表元素(链表)
java·算法·leetcode·链表
不染尘.2 小时前
背包问题BP
开发语言·c++·算法
进击的小头2 小时前
第17篇:卡尔曼滤波器之概率论初步
python·算法·概率论
2401_874732532 小时前
基于C++的爬虫框架
开发语言·c++·算法
Q741_1472 小时前
力扣经典模板题 前缀积 力扣 2906. 构造乘积矩阵 每日一题 哈希表 找规律 力扣 13. 罗马数字转整数 C++
算法·leetcode·前缀和·矩阵