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;
}
相关推荐
一只齐刘海的猫4 分钟前
【Leetcode】移动零
算法·leetcode·职场和发展
落羽的落羽1 小时前
【项目】JsonRpc框架——开发实现1(细节功能、字段定义、抽象层、具象层)
linux·服务器·网络·c++·人工智能·算法·机器学习
handler011 小时前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
qq7422349842 小时前
从“感知”到“决断”:测评百度伐谋产业决策智能体的端到端推理与行动机制
人工智能·算法·百度·大模型·运筹优化
huohaiyu2 小时前
深入解析Java垃圾回收机制
java·开发语言·算法·gc
浮芷.2 小时前
鸿蒙PC端 TTS 并发调用问题详解:资源竞争与队列管理
算法·华为·开源·harmonyos·鸿蒙·鸿蒙系统
装不满的克莱因瓶3 小时前
掌握感知器的学习原理
人工智能·python·神经网络·算法·ai·卷积神经网络
Lsk_Smion3 小时前
力扣实训 _ [994].腐烂的橘子/图论
算法·leetcode·图论
轻微的风格艾丝凡3 小时前
两电平三相VSC整流模式从不控整流平滑切换至有源整流调试记录
算法·dsp·c2000
dongf20193 小时前
R语言KNN算法
算法·数据分析·r语言