当前位置: 首页 > news >正文

拓扑排序(c++)

拓扑排序:可以对有向图的数据按照先后顺序进行排序,也可以用来检测有向图中有没有环

题目

课程表

题目描述

你这个学期必须选修n门课程,记为0到n-1。在选修某些课程之前需要一些先修课程。给你一个数组p,其中p[i]=[ai,bi]表示如果想选修课程ai,则必须先选修课程bi。m表示数组p中数据个数

例如,想要学习课程0,你需要先完成课程1,我们用一个匹配来表示:[0,1]。

先输入n、m,再输入数组p。
请你判断是否可能完成所有课程的学习?如果可以,返回true;否则,返回false。

样例

输入:

2 2

1 0

0 1

输出

false

解释:课程1需要先学0,课程0又需要先学1,存在循环依赖,不可能完成。

代码

#include <bits/stdc++.h> using namespace std; int a[1010][1010];//邻接矩阵 int c[1010];//入度 int b[1010];//是否被访问 int r[1010];//排序结果 int lr; int n,m; queue<int> q; void bfs(); int main() { cin>>n>>m; for(int i = 0;i<m;i++) { int x,y; cin>>x>>y; a[y][x] = 1;//构建邻接矩阵 c[x]++;//增加入度的数量 } bfs(); if(lr==n) cout<<"true"; else cout<<"false"; return 0; } void bfs() { for(int i = 0;i<n;i++) { if(c[i]==0)//入度等于0 { q.push(i); b[i] = 1;//标记已被访问 r[lr] = i;//排序 lr++; } } while(q.empty()==false) { int head = q.front(); q.pop(); for(int i = 0;i<n;i++) { if(a[head][i]==1&&b[i]==0) { c[i]--; if(c[i]==0) { q.push(i); b[i] = 1;//标记已被访问 r[lr] = i;//排序 lr++; } } } } }

课程表二

题目描述

现在你总共有n门课,编号为0到n-1。给你一个数组p,其中p[i=[ai,bi表示如果你想选修课程ai,则必须先完成课程bi。例如,[0,1]表示要选修课程0,必须先选修课程1。返回一种修完所有课程的顺序(可能存在多种有效顺序,你只需要返回其中一种)。如果不可能完成所有课程,返回一个空数组。m表示数组p中数据个数。

先输入n、m,再输入数组p。

样例

输入

4 4

1 0

2 0

3 1

3 2

输出

0 1 2 3

(0 2 1 3 也可以)

代码

#include <bits/stdc++.h> using namespace std; int a[1010][1010];//邻接矩阵 int c[1010];//入度 int b[1010];//是否被访问 int r[1010];//排序结果 int lr; int n,m; queue<int> q; void bfs(); int main() { cin>>n>>m; for(int i = 0;i<m;i++) { int x,y; cin>>x>>y; a[y][x] = 1;//构建邻接矩阵 c[x]++;//增加入度的数量 } bfs(); if(lr==n) { for(int i = 0;i<lr;i++) { cout<<r[i]<<" "; } } else { cout<<0; } return 0; } void bfs() { for(int i = 0;i<n;i++) { if(c[i]==0)//入度等于0 { q.push(i); b[i] = 1;//标记已被访问 r[lr] = i;//排序 lr++; } } while(q.empty()==false) { int head = q.front(); q.pop(); for(int i = 0;i<n;i++) { if(a[head][i]==1&&b[i]==0) { c[i]--; if(c[i]==0) { q.push(i); b[i] = 1;//标记已被访问 r[lr] = i;//排序 lr++; } } } } }
http://www.jsqmd.com/news/916316/

相关文章:

  • FPGA加速器GeneTEK在基因组序列比对中的高效能表现
  • Kubernetes StatefulSet实践与分布式系统部署
  • DLSS Swapper完全指南:免费开源的游戏DLSS文件管理终极方案
  • 50美元DIY房间声学校正器:用树莓派Pico和REW优化听音环境
  • 如何高效使用COM3D2.MaidFiddler:终极COM3D2角色编辑器完整指南
  • ELF技术:机器学习加速逻辑综合的工程实践
  • 免费歌词制作神器:5分钟掌握专业级LRC歌词同步技巧
  • 如何用Sunshine在10分钟内搭建个人游戏云:跨平台游戏串流完整指南
  • 如何挑选合适的支付机构代付业务?
  • 终极AMD Ryzen调试指南:SMU Debug Tool完整使用教程
  • Word转PDF的方法有哪些?2026保姆级教程,含官方方法一看就会
  • 3个思维转变:用AlienFX Tools将你的Alienware从工具变为伙伴
  • CNC雕刻与VCarve Pro实战:将三维地形数据转化为木质景观时钟
  • AI代理从演示到生产:跨越复合错误率与可靠性鸿沟的实战指南
  • 基于TM4C123GH6PM的西蒙游戏实现:从寄存器操作到嵌入式系统设计
  • 自动驾驶语义分割:TSLA框架与MobileNetV4优化实践
  • Nextion HMI智能相框:全局变量与页面刷新实现动态切换效果
  • 颠覆传统:Seraphine智能助手如何用3大核心功能重塑你的英雄联盟游戏体验
  • 推拉力测试机操作教程:从零基础到熟练测试,一文搞定硬件安装+软件设定+校准
  • GeoScene Pro制图效率翻倍秘籍:善用图层组与标注脚本,告别重复劳动
  • Beyond Compare 5密钥生成终极指南:深度技术解析与高效激活方案
  • Python学习第53天:前后端分离开发入门
  • Python异步编程高级模式:asyncio事件循环与并发控制
  • 保姆级教程:彻底清理Win11更新缓存并解除外设,一次搞定0xc1900101更新错误
  • 从零自制简易直流电机:深入理解电磁原理与动手实践
  • Redis 数据类型命令详解
  • 抖音短视频无水印下载技术解析:从网页解析到桌面应用的完整实现方案
  • ChatGPT如何解答奇葩谜题:从原理到实践的全方位解析
  • 手把手教你:在戴尔R730XD上为Windows Server 2019配置NIC组合与Hyper-V
  • CPAL脚本避坑指南:TestcaseFail和TestCaseSkipped用不对,小心你的测试结果全乱套