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

惠新西街网站建设青海西宁网站开发公司

惠新西街网站建设,青海西宁网站开发公司,建一个网站难不难,网页免费视频教程有向图的拓扑排序就是图的宽度优先遍历的一个应用 有向无环图一定存在拓扑序列(有向无环图又被称为拓扑图),有向有环图一定不存在拓扑序列。无向图没有拓扑序列。 拓扑序列:将一个图排成拓扑序后,所有的边都是从前指…

有向图的拓扑排序就是图的宽度优先遍历的一个应用

有向无环图一定存在拓扑序列(有向无环图又被称为拓扑图),有向有环图一定不存在拓扑序列。无向图没有拓扑序列。

拓扑序列:将一个图排成拓扑序后,所有的边都是从前指向后的。

入度:有多少条边指向自己

出度:有多少条边指向别人

入度为0的点都可以排在最前边

#include<iostream>
#include<cstring>using namespace std;const int N = 100010;int n, m;
int h[N], e[N], ne[N], idx;
int q[N];
int d[N]; //入度void add(int a, int b)
{e[idx] = b, ne[idx] = h[a]; h[a] = idx ++ ;
}bool toposort()
{int hh = 0, tt = -1;for(int i = 1; i <= n; i ++ ){if(!d[i]) q[ ++ tt] = i; \\入度为零的点推入队列}while(hh <= tt){int t = q[hh ++ ];for(int i = h[t]; i != -1; i = ne[i]){int j = e[i]; //枚举t的所有出边jd[j] -- ; /删掉t -> j边,j的入度--if(d[j] == 0) q[ ++ tt] = j; //如果j的入度==0,推入队列}}return tt == n - 1; //如果队尾 == n - 1说明所有点都进过队列了,说明该图是一个有向无环图
}int main()
{cin >> n >> m;memset(h, -1, sizeof h);while(m -- ){int a, b;cin >> a >> b;add(a, b);d[b] ++ ;}if(toposort()){for(int i = 0; i < n; i ++ ) cout << q[i] << " ";}else cout << -1 << endl;return 0;
}

http://www.yayakq.cn/news/149815/

相关文章:

  • 网站建设实训计划书建立网站 域名 服务器
  • 甘肃再就业建设集团网站羽毛球赛事最新消息
  • 网站打不开的解决方法私域流量代运营公司
  • 网站域名备案认证怎样做引流推广
  • 做网站建设的怎么寻找客户东莞关键字排名优化
  • 建站源码下载网站建设自查维护报告
  • 电商平台网站多少钱如何成为app推广代理
  • 外贸看的英文网站淘宝网建设网站意义
  • 住房和城乡建设厅官方网站最干净在线网页代理
  • 网站开发的工作总结网站建设存在的具体问题
  • 手机网站菜单栏怎么做电商网站设计思维导图
  • 网站建设中怎样设置背景如何修改公司网站
  • 北京化妆品网站建设什么内容能提高网站流量
  • 龙岗做手机网站建设工程信息公示网
  • 阜新网站推广昆明短视频运营公司
  • 词条有哪些网站可以做深圳市住房和建设局招聘
  • 织梦绑定网站出现错误免费ppt模板下载网址推荐
  • 网站改版的方式大致有郑州网站建设方案
  • discuz网站备份2345网址导航下载
  • 天津做网站的公司排名用织梦做的网站 图片打开很慢
  • 建网站销售常见问题qt设计精美ui
  • 门户网站要用什么软件做汕头个人网站建设
  • 郑州网站建设专家物业建设网站
  • 提供做网站服务好美团app开发费用
  • 公众号里的电影网站怎么做的东莞建材网站建设
  • 黑河做网站公司莱芜网络推广专家
  • 网站制作是那个人工智能和网站开发
  • 网站管理系统墨鱼wordpress
  • dede电影网站模板全网最全搜索引擎app
  • 哈尔滨网站制作专业达州网络推广