拓扑排序C++实现+实例解析(详解 兄弟们冲呀呀呀呀呀呀呀)

一:引言

既然是一种排序,那么肯定是按照某种规则进行排序,那么这么想的话,先了解基本知识,再来实战演练
1. AOV网(Activity On Vertex Network)【顶点——表示活动】
是一个——有向无回路的图
顶点——表示活动
用弧——表示活动间的优先关系的有向图称为-顶点表示活动的网
即如果a->b,那么a是b的先决条件
求拓扑序列就是AOV
2.
用邻接矩阵存储时 每一列表示这个顶点的入度(有向图中)

二:上码

/* 1.AOV网(Activity On Vertex Network)【顶点——表示活动】是一个——有向无回路的图顶点——表示活动用弧——表示活动间的优先关系的有向图称为-顶点表示活动的网即如果a->b,那么a是b的先决条件求拓扑序列就是AOV2.用邻接矩阵存储时 每一列表示这个顶点的入度(有向图中)	
*/
#include<bits/stdc++.h>
using namespace std;typedef struct GNode* PtrGraph;
typedef struct GNode{int Nv;int Ne;int Date[100][100];
}gnode;int cnt; //统计每个结点的入度 
vector<int>v;//存入度的 
vector<int>v1;//记录拓扑序列 //创建图
void creatrGraph(PtrGraph G){int N,M;cin >> N >> M;G->Nv = N;G->Ne = M;//矩阵初始化for( int i = 0; i < G->Nv; i++ ){for(int j = 0; j < G->Nv; j++ ){G->Date[i][j] = 0;}} //矩阵赋值for(int i = 0; i < G->Ne; i++ ){int a,b;cin >> a >> b;G->Date[a][b] = 1;//有向图	} 	
} 
//求取每一列的数据和即为该顶点的入度
void degree(PtrGraph G){for(int j = 0; j < G->Nv; j++ ){cnt = 0;for( int i = 0; i < G->Nv; i++ ){if(G->Date[i][j] == 1)cnt++;}v.push_back(cnt);}
}  
//求拓扑序列void topology( PtrGraph G ){queue<int>q;int count = 0;//用于计算度数为0的结点的个数 for( int i = 0; i < G->Nv; i++ ){if(v[i] == 0)q.push(i);//将入度为0的入队		} //这里就是处理每次去掉一个度数为0的点和其有关系的顶点度数减一 while( !q.empty() ){int temp = q.front();q.pop();v1.push_back(temp); count++;for( int j = 0; j < G->Nv; j++ ){//列 if( G->Date[temp][j] == 1  ){//在 temp 这一行中 等于 1的 j 需要入度减一 	v[j]--;//其入度减一if( v[j] == 0 ){q.push(j);// 将入度为0的入度 }}}} if( G->Nv  == count ){//没有环 for( int i = 0; i < v1.size(); i++ )cout << v1[i] << ' '; 	}else{cout << "此图有环"; } } int main(){PtrGraph G = (PtrGraph)malloc(sizeof(struct GNode));creatrGraph(G);degree(G);topology(G);} //5 6
//0 1
//0 2
//1 3
//2 1
//2 4
//3 4
//拓扑序列为:0 2 1 3 4

在这里插入图片描述
加油boy 冲呀

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/308394.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php yaf smarty,Yaf 结合用户自定义的视图(模板)引擎Smarty(Yaf + Smarty)

Yaf 结合用户自定义的视图(模板)引擎Smarty(Yaf Smarty)来源&#xff1a;互联网作者&#xff1a;佚名时间&#xff1a;2015-08-06 07:55对完成某个任务进行计时可使用progress_timer类&#xff0c;这个类对象在退出作用范围后&#xff0c;会输出对象创建后过去的时间&#xff…

7-34 任务调度的合理性 (25 分)(思路加详解+兄弟们冲呀)

一&#xff1a;题目 假定一个工程项目由一组子任务构成&#xff0c;子任务之间有的可以并行执行&#xff0c;有的必须在完成了其它一些子任务后才能执行。“任务调度”包括一组子任务、以及每个子任务可以执行所依赖的子任务集。 比如完成一个专业的所有课程学习和毕业设计可…

.NET和.NET Core Web APi FormData多文件上传

【导读】最近因维护.NET和.NET Core项目用到文件上传功能&#xff0c;虽说也做过&#xff0c;但是没做过什么对比&#xff0c;借此将二者利用Ajax通过FormData上传文件做一个总结&#xff0c;通过视图提交表单太简单&#xff0c;这里不做阐述&#xff0c;希望对有需要的童鞋能有…

php 百度云 上传,求个PHP版百度云BOS上传文件的dome

[HTML] 纯文本查看 复制代码bce-bos-uploader simple demo开始上传var uploader new baidubce.bos.Uploader({browse_button: #file,bos_bucket: ,bos_endpoint: ,bos_ak: ,bos_sk: ,max_file_size: 1Gb,init: {FileUploaded: function (_, file, info) {var bucket info.bod…

在ubuntu上实现基于webrtc的多人在线视频聊天服务

最近研究webrtc视频直播技术&#xff0c;网上找了些教程最终都不太能顺利跑起来的&#xff0c;可能是文章写的比较老&#xff0c;使用的一些开源组件已经更新了&#xff0c;有些配置已经不太一样了&#xff0c;所以按照以前的步骤会有问题。折腾了一阵终于跑起来了&#xff0c;…

java并发练习之快乐影院

一&#xff1a;引言 这里是加了个同步块&#xff0c;来保证数据的准确性&#xff0c;用了个容器使&#xff0c;我们可以选位置 二&#xff1a;上码&#xff08;这里是模拟在电影院选位置&#xff09; package com.wyj.three;import java.util.ArrayList; import java.util.L…

用php编写一个日志系统,php利用单例模式实现日志处理类库

对于现在的应用程序来说&#xff0c;日志的重要性是不言而喻的。很难想象没有任何日志记录功能的应用程序运行在生产环境中。日志所能提供的功能是多种多样的&#xff0c;包括记录程序运行时产生的错误信息、状态信息、调试信息和执行时间信息等。在生产环境中&#xff0c;日志…

Azure DevOps+Docker+Asp.NET Core 实现CI/CD(二.创建CI持续集成管道)

前言本文主要是讲解如何使用Azure DevOpsDocker 来实现持续集成Asp.NET Core项目(当然 也可以是任意项目).上一篇:Azure DevOpsDockerAsp.NET Core 实现CI/CD(一 .简介与创建自己的代理池)觉得有帮助的朋友~可以左上角点个关注,右下角点个推荐今天我们废话不多说 直接开始正文 …

7-35 城市间紧急救援 (25 分)(思路加详解)

一&#xff1a;题目 作为一个城市的应急救援队伍的负责人&#xff0c;你有一张特殊的全国地图。在地图上显示有多个分散的城市和一些连接城市的快速道路。每个城市的救援队数量和每一条连接两个城市的快速道路长度都标在地图上。当其他城市有紧急求助电话给你的时候&#xff0…

程序员修神之路--那些分布式事务解决方案

亲爱的,关注我吧为了保证分布式环境下数据强一致性&#xff0c;需要引入分布式事务&#xff0c;而分布式事务由于网络环境的不确定性&#xff0c;天生就很难实现。具体可以见上一篇。[分布式下&#xff0c;我想要强一致性]为了保证分布式事务的正确性&#xff0c;目前互联网领域…

7-36 社交网络图中结点的“重要性”计算 (30 分)(思路加详解)兄弟们PTA乙级题目冲起来

一&#xff1a;题目 在社交网络中&#xff0c;个人或单位&#xff08;结点&#xff09;之间通过某些关系&#xff08;边&#xff09;联系起来。他们受到这些关系的影响&#xff0c;这种影响可以理解为网络中相互连接的结点之间蔓延的一种相互作用&#xff0c;可以增强也可以减…

php防止cc攻击代码,防cc攻击PHP防CC攻击实现代码

这种时候您的统计系统(可能是量子、百度等)当然也是统计不到的。不过我们可以借助于一些防攻击的软件来实现&#xff0c;不过效果有时并不明显。下面我提供一段PHP的代码&#xff0c;可以起到一定的防CC效果。主要功能&#xff1a;在3秒内连续刷新页面5次以上将指向本机 http:/…

分享几个亲测有效的高效工作技巧

这里是Z哥的个人公众号每周五11&#xff1a;45 按时送达当然了&#xff0c;也会时不时加个餐&#xff5e;我的第「154」篇原创敬上大家好&#xff0c;我是Z哥。在工作中&#xff0c;你会发现有的小伙伴每天看上去很忙&#xff0c;但是好像产出的成果比旁边看上去工作轻松甚至有…

js变量和java变量相等,js中变量和jsp中java代码中变量互相访问解决方案

1。js变量获取jsp页面中java代码的变量值。方法&#xff1a;var JS变量名 我们常常会将js文件和jsp文件分开写&#xff0c;在js文件中&#xff0c;上面的方法似乎不管用了。也可以通过变通的方法来解决&#xff1a;a.jspaa.jsvar n document.getElementById(a).value; 使用jq…

7-37 模拟EXCEL排序 (25 分)(思路+详解+超时解决 兄弟们冲呀呀呀呀呀呀)

一&#xff1a;题目 Excel可以对一组纪录按任意指定列排序。现请编写程序实现类似功能。 输入格式: 输入的第一行包含两个正整数N(≤10 5 ) 和C&#xff0c;其中N是纪录的条数&#xff0c;C是指定排序的列号。之后有 N行&#xff0c;每行包含一条学生纪录。每条学生纪录由学号…

Azure DevOps+Docker+Asp.NET Core 实现CI/CD(三.实现CD持续部署管道)

前言本文主要是讲解如何使用Azure DevOpsDocker 来实现持续集成Asp.NET Core项目(当然 也可以是任意项目).上一篇:Azure DevOpsDockerAsp.NET Core 实现CI/CD(一 .简介与创建自己的代理池)Azure DevOpsDockerAsp.NET Core 实现CI/CD(二.创建CI持续集成管道)觉得有帮助的朋友~可…

7-1 寻找大富翁 (25 分)(思路加详解+两种做法(一种优先队列,一种vector容器))

一&#xff1a;题目 胡润研究院的调查显示&#xff0c;截至2017年底&#xff0c;中国个人资产超过1亿元的高净值人群达15万人。假设给出N个人的个人资产值&#xff0c;请快速找出资产排前M位的大富翁。 输入格式: 输入首先给出两个正整数N&#xff08;≤10 6 &#xff09;和M…

php项目通过不了压力测试,压力测试 – Apache ab测试和失败 – Apache或PHP配置问题?...

我写了一个RESTful Web服务,成为使用PHP和Restler库的移动应用程序的支柱.它运行在运行Windows Server 2008 R2,PHP 5.3.5,Apache 2.2.17和MySQL 5.5.8的开发服务器上.只是为了咯咯笑,我决定对我的开发服务器进行基准测试并遇到可能的配置问题如果我通过Windows CLI运行ab -k -…

matlab调用时间序列工具箱,matlab时间序列工具箱

【实例简介】matlab时间序列工具箱&#xff0c;【实例截图】【核心代码】824a746f-8093-4767-8426-cf0f7ceda7a6├── matrixcomp│ ├── adsmax.m│ ├── augment.m│ ├── cholp.m│ ├── chop.m│ ├── cod.m│ ├── Contents.m│ ├── cpltax…

7-39 魔法优惠券 (25 分)(思路加解释 用容器做的)加油兄弟们

一&#xff1a;题目 在火星上有个魔法商店&#xff0c;提供魔法优惠券。每个优惠劵上印有一个整数面值K&#xff0c;表示若你在购买某商品时使用这张优惠劵&#xff0c;可以得到K倍该商品价值的回报&#xff01;该商店还免费赠送一些有价值的商品&#xff0c;但是如果你在领取…