2022 icpc 西安站 L. Tree - 拓扑排序

题面

分析

题意就是求集合个数,满足集合所有点都是子节点和父节点关系或者不存在祖孙关系。那么可以将树拆分成若干条链,然后每次减少链数,将减少的链转化成另一种情况,也就是枚举所有链数的方案,取最小值。

对于求链数,也就是统计叶节点的个数,可以通过拓扑排序进行统计叶节点数量,然后通过删去一层叶节点来减少链数,实现了枚举所有方案。

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

#define int long long

using namespace std;

const int N = 1e6 + 10;

int fa[N];
int d[N];

void solve() {
    int n;
    cin >> n;
    for(int i = 1; i <= n; i ++) {
        fa[i] = 0;
        d[i] = 0;
    }
    for(int i = 2; i <= n; i ++) {
        int x;
        cin >> x;
        fa[i] = x;
        d[i] ++;
        d[x] ++;
    }
    queue<int> q;
    for(int i = 2; i <= n; i ++) {
        if(d[i] == 1) {
            q.push(i);
        }
        d[i] --;
    }
    int ans = n;
    int k = 0;
    while(q.size()) {
        int sz = q.size();
        ans = min(ans, k + sz);
        k ++;
        while(sz --) {
            int t = q.front();
            q.pop();
            if(fa[t] == 0) continue;
            d[fa[t]] --;
            if(d[fa[t]] == 0) q.push(fa[t]);
        }
    }
    cout << ans << "\n";
}

signed main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    int T;
    cin >> T;
    while(T --) {
        solve();
    }
}
相关推荐
不会C语言的男孩32 分钟前
C++ Primer Plus 第8章:函数探幽
开发语言·c++
William_wL_36 分钟前
【C++】模板进阶
c++
MC皮蛋侠客8 小时前
Google Test 单元测试指南
c++·单元测试·google test
艾莉丝努力练剑8 小时前
【Linux:文件】Ext系列文件系统进阶
linux·运维·服务器·c++·文件系统·文件io·ext
kkeeper~9 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
wabs66610 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_8769641310 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
basketball61610 小时前
C++ NULL 和 nullptr 区别 以及 nullptr 的核心实现
java·开发语言·c++
嗝o゚11 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本11 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试