笔试题8 -- 利用拓扑排序解决体育课测验

笔试题8 -- 利用拓扑排序解决体育课测验

原题重现

题目链接:体育课测验(二)_牛客 (nowcoder.com)

体育课共有 numProject 个考核项目,编号为 0 到 numProject−1。考核中每两个项目被划分为一组得到分组数组 groupsi,现规定若想完成项目 groupsi 0,必须先完成 groupsi 1。保证所有分组互不相同,若分组情况能顺利完成考核,请返回任意的一个完成顺序,否则返回空数组。

数据范围:

  1. 1 ≤ numProject ≤ 2000
  2. 1 ≤ groupsi.length ≤ numProject * (numProject−1)

解题思路

通过题目描述 "若想完成项目 groupsi 0,必须先完成 groupsi 1" ,这说明同组的两项目之间存在先后顺序,且每组内刚好有两个项目,他们之间的先后关系可以用箭头来表示 groupsi 0 <- groupsi 1 ,所以联想到利用拓扑排序可以有效解决该问题。

示例代码

本代码利用Kahn算法实现拓扑排序

cpp 复制代码
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param numProject int整型 
     * @param groups int整型vector<vector<>> 
     * @return int整型vector
     */
    vector<int> findOrder(int numProject, vector<vector<int> >& groups) {
        vector<vector<int>> edges(numProject);  // 存储边
        vector<int> in(numProject);  // 存储入度

        // 1.建图
        for(auto pair: groups)
        {
            // pair[0] <- pair[1]
            edges[pair[1]].push_back(pair[0]);
            in[pair[0]]++;
        }

        // 2.入度为0的点,加入到队列中
        queue<int> q;
        for(int i = 0; i < numProject; i++)
        {
            if(in[i] == 0) { q.push(i); }
        }

        // 3.拓扑排序(层序遍历)
        vector<int> ret;
        while(!q.empty())
        {
            auto a = q.front();
            q.pop();
            // 塞入结果数组
            ret.push_back(a);
            // 移除该点相关信息
            // a -> b
            for(auto b: edges[a])
            {
                if(--in[b] == 0)  // 已经入度为0的点就可以利用队列准备放入结果数组
                {
                    q.push(b);
                }
            }
        }

        // 4.返回
        if(ret.size() == numProject) { return ret; }
        return {};
    }
};

提交结果:

相关推荐
liulilittle6 分钟前
论 Linux 内核态全局稳态带宽的卡尔曼估计与工程实现
linux·服务器·网络·c++·计算机网络·tcp·通信
XBodhi.8 分钟前
Visual Studio C++ 语法错误: 缺少“;”(在“return”的前面)
开发语言·c++·visual studio
科研online16 分钟前
基于多源数据和XGBoost-SHAP分析中国大陆绿地碳汇空间变异影响因素的非线性相关性与尺度差异
算法·学习方法
Cthy_hy36 分钟前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
三品吉他手会点灯1 小时前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
VkN2X2X4b1 小时前
算法复杂度的实验验证与误差分析的技术8
算法
其利天下技术1 小时前
风扇灯无刷电机自适应算法实战指南
算法·cocos2d·无刷电机自适应算法·bldc驱动自适应算法·其利无刷电机驱动算法
8Qi81 小时前
LeetCode 494:目标和(Target Sum)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
hujinyuan201602 小时前
2026年3月 中国电子学会青少年软件编程(Python)三级考试试卷 真题及答案
java·python·算法
froyoisle2 小时前
CSP-J 历年复赛 T1 及解析(2019~2025)
数据结构·c++·算法·csp-j·csp·算法竞赛·信息学