POJ 2367 Genealogical tree【拓扑排序】
题意:大概意思是--有一个家族聚集在一起,现在由家族里面的人讲话,辈分高的人先讲话。现在给出n,然后再给出n行数 第i行输入的数表示的意思是第i行的子孙是哪些数,然后这些数排在i的后面。
比如样例 5
0
4 5 1 0
1 0
5 3 0
3 0
1后面没有数
2后面有4 5 1
3后面有1
4后面有5 3
5后面有3
拓扑排序的一点小体会
(1)先把图储存下来,然后储存相应顶点的度数
(2)在图中选择没有前驱的点(即入度为0的点),加入队列中
(3)将以这一点为起点的边删去(将这一点指向的点的入度减1)
(4)重复上面的操作,直到没有入度为0的点
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int iq,n;
int queue[1000],map[1000][1000],indegree[1000];void toposort()
{int i,j,k;iq=0;for(i=1;i<=n;i++){for(j=1;j<=n;j++){if(map[i][j])indegree[j]++; }}for(i=1;i<=n;i++){for(j=1;j<=n;j++){if(indegree[j]==0){queue[iq++]=j;break;}}indegree[j]=-1;//把这一点加进去以后,将这一点的入度记为-1,以免下次又将它加进队列 for(k=1;k<=n;k++){if(map[j][k])indegree[k]--;} }
} int main()
{int i,v;scanf("%d",&n);for(i=1;i<=n;i++){while(scanf("%d",&v)!=EOF&&v)map[i][v]=1; }toposort();for(i=0;i<iq-1;i++)printf("%d ",queue[i]);printf("%d",queue[i]);
}
拓扑排序的第一题--@_@
go--go
转载于:https://www.cnblogs.com/wuyuewoniu/p/4276620.html
POJ 2367 Genealogical tree【拓扑排序】相关推荐
- 图论之拓扑排序 poj 2367 Genealogical tree
题目链接 http://poj.org/problem?id=2367 题意就是给定一系列关系,按这些关系拓扑排序. #include<cstdio> #include<cstrin ...
- [POJ] 3687 Labeling Balls(拓扑排序)
题目地址:http://poj.org/problem?id=3687 反向建边,即重的球指向轻的球,注意重边,然后拓扑排序.从n-->1循环,即每次从入度为0的球里面选编号大的存(包含输入的逻 ...
- [cf] E - Gardener and Tree 拓扑排序
前言 传送门 : 一开始想到了拓扑排序 但是拓扑是对一个点,所以还是想着中心根深度继续走 思路 我们对于每一个叶子节点 对其连接的节点的度数−1-1−1 进行拓扑操作 然后我们在操作的时候 同时记录一 ...
- POJ 1128 Frame Stacking 拓扑排序+暴搜
这道题输出特别坑.... 题目的意思也不太好理解.. 就解释一下输出吧.. 它让你 从下往上输出. 如果有多种情况,按照字典序从小往大输出... 就是这个多种情况是怎么产生的呢. 下面给一组样例. 很 ...
- 拓扑排序题集【夏天的风】
[HDU] 1285 确定比赛名次 2094 产生冠军 2647 Reward 3342 Legal or Not 1811 Rank of Tetris 拓扑+并查集 3231 Box Rela ...
- 拓扑排序 POJ - 3687反向图跑字典序(重边)
题目链接:http://poj.org/problem?id=3687 题目大意: 给定N个球,这些球的编号分别是1-N中的某个数字,它们的重量也分别是1-N中的某个数字,任意两个球的编号和重量不相等 ...
- poj 3687(拓扑排序)
http://poj.org/problem?id=3687 题意:有一些球他们都有各自的重量,而且每个球的重量都不相同,现在,要给这些球贴标签.如果这些球没有限定条件说是哪个比哪个轻的话,那么默认的 ...
- poj 4084:拓扑排序
poj 4084:拓扑排序 非常好的题目,恶心的算法 描写叙述 给出一个图的结构,输出其拓扑排序序列,要求在同等条件下.编号小的顶点在前. 输入 若干行整数,第一行有2个数,分别为顶点数v和弧数a,接 ...
- Poj 1094 拓扑排序Kahn
Poj 1094 拓扑排序Kahn Sorting It All Out Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 4133 ...
最新文章
- php判断网页编码,python判断网页编码的方法
- java中保存图片到本地_java保存网络图片到本地
- mfc让图片与按钮一起_微信朋友圈发图片还能添加语音,简单两步就能搞定!今天学到了...
- 如何成为一名数据科学家?(二)
- linux下重启weblogic(关闭和启动)
- java安全编码指南之:异常处理
- php中mimes函数,wordpress函数check_upload_mimes()用法示例
- 牛客 2021年度训练联盟热身训练赛第二场 D题Soccer Standings
- 连续特征离散化--汇总
- 2023年厦门大学全日制会计专硕(MPAcc)考研上岸前辈备考经验
- 2015年数学建模-A影子定位
- OpenCV图像处理之直方图
- 深度解析:印度软件产业为何如此发达
- Post Office
- c#实现类似Sublime Text文本编辑器、电脑屏幕画板
- 弘辽科技:淘宝宝贝标题怎么找准关键词?做标题的3个学问
- HTTP-XMLHttpRequest
- 23种设计模式之代理模式
- RHCSA认证考试---5.配置 crontab
- 通达+oa+php+文件+乱,通达OA 任意文件上传+文件包含导致RCE
热门文章
- 自定义 Javascript 模板规则,打造轻量级模板引擎
- 使用PostBackUrl属性实现跨页面传值
- MySQL 5.1.45 GA 发布
- 两张照片重叠处半透明_那些悬浮在空中的照片是怎么拍的?
- Rust FFI 编程--理解不同语言的数据类型转换
- 基于pytorch实现图像分类——理解自动求导、计算图、静态图、动态图、pytorch入门
- (25)FPGA工程师与其他工程师交集(FPGA不积跬步101)
- (96)分频器设计(任意分频器)
- linux服务器拓扑图,Linux服务器作为网关的DNS分离解析服务(CentOS 7版本)
- 【蓝桥杯嵌入式】【STM32】7_RTC之实时时间显示和硬件闹钟设置