【改了一天的拓扑排序】POJ 1094——Sorting It All Out
来源:点击打开链接
不知道怎么回事,wa了整整一天。。在绝望的时候AC了。
重点是分步处理和三种情况的判断。
1、判断是否成环,成环了直接输出错误信息。
2、然后一条边一条边的加入,进行拓扑排序,如果出度为0的点多于两个,继续判断之,如果到所有点都加入了但仍然没有判断出来,输出第三种情况。
3、以上两种情况都不存在,输出拓扑排序的路径信息。
#include <iostream>
#include <cstring>
#include <string>
using namespace std; int mat[105][105];
int ans[105];
int indegree[105];
int length,rela,tflag,loopflag; int TopoLogic()
{
int loopcount=0;//0入度数统计
int entrypoint=0;//第几个检测到0入度,加入队列
int t=0;
int flag=1; memset(indegree,0,sizeof(indegree)); for (int a=0;a<length;a++) //求目前图的入度
{
for (int b=0;b<length;b++)
{
if (mat[a][b])
indegree[b]++;
}
}
for (int i=0;i<length;i++)
{
loopcount=0;
for (int j=0;j<length;j++)
{
if (indegree[j]==0)
{
loopcount++;
entrypoint=j;
}
}
if (loopcount>1)
flag=-1; //出现多种情况,不好说
if (loopcount==0 && loopcount!=length)//第二个条件很容易忘
return 0; ans[t++]=entrypoint;
indegree[entrypoint]=-1;//去点
for (int p=0;p<length;p++)
{
if (mat[entrypoint][p]==1)
indegree[p]--;
} }
return flag; } int main()
{ while (cin>>length>>rela)
{
if (length==0 && rela==0)
break;
memset(mat,0,sizeof(mat));
memset(indegree,0,sizeof(indegree)); tflag=0;//队列标志
string tar; for (int t=1;t<=rela;t++)
{
int resulter;
cin>>tar;
mat[tar[0]-'A'][tar[2]-'A']=1;
memset(ans,0,sizeof(ans));
if (tflag==0)
{
resulter=TopoLogic();
//cout<<resulter<<endl;
} if (resulter==1 && tflag==0)
{
cout<<"Sorted sequence determined after "<<t<<" relations: ";
for (int a=0;a<length;a++)
cout<<(char)(ans[a]+'A');
cout<<"."<<endl;
tflag=1;
} if(resulter==0 && tflag==0)
{
cout<<"Inconsistency found after "<<t<<" relations."<<endl;
tflag=1;
} }
if(tflag==0)
cout<<"Sorted sequence cannot be determined."<<endl; //全部判断完再输出矛盾!! }
return 0;
}
【改了一天的拓扑排序】POJ 1094——Sorting It All Out的更多相关文章
- 拓扑排序 POJ 1094 Sorting It All Out
题意:给定N个字和M行他们之间的关系,要求输出他们的拓扑排序.此题采用边输入边检测的方式,如果发现环,就结束并输出当前行号:如果读取到当前行时,可以确定拓扑序列就输出,不管后面的输入(可能包含环路): ...
- 拓扑排序 POJ 1049 Sorting It All Out
题目传送门 /* 拓扑排序裸题:有三种情况: 1. 输入时发现与之前的矛盾,Inconsistency 2. 拓扑排序后,没有n个点(先判断cnt,即使一些点没有边连通,也应该是n,此时错误是有环): ...
- ACM: poj 1094 Sorting It All Out - 拓扑排序
poj 1094 Sorting It All Out Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%lld & ...
- 拓扑排序(Topological Sorting)
一.什么是拓扑排序 在图论中,拓扑排序(Topological Sorting)是一个有向无环图(DAG, Directed Acyclic Graph)的所有顶点的线性序列.且该序列必须满足下面两个 ...
- 拓扑排序 POJ 2367
今天网易的笔试,妹的,算法题没能A掉,虽然按照思路写了出来,但是尼玛好歹给个测试用例的格式呀,吐槽一下网易的笔试出的太烂了. 就一道算法题,比较石子重量,个人以为解法应该是拓扑排序. 就去POJ找了道 ...
- [ACM_模拟] POJ 1094 Sorting It All Out (拓扑排序+Floyd算法 判断关系是否矛盾或统一)
Description An ascending sorted sequence of distinct values is one in which some form of a less-than ...
- poj 1094 Sorting It All Out (拓扑排序)
http://poj.org/problem?id=1094 Sorting It All Out Time Limit: 1000MS Memory Limit: 10000K Total Su ...
- 图论之拓扑排序 poj 2367 Genealogical tree
题目链接 http://poj.org/problem?id=2367 题意就是给定一系列关系,按这些关系拓扑排序. #include<cstdio> #include<cstrin ...
- POJ 1094 Sorting It All Out (拓扑排序,判断序列是否唯一,图是否有环)
题意:给出n个字符,m对关系,让你输出三种情况: 1.若到第k行时,能判断出唯一的拓扑序列,则输出: Sorted sequence determined after k re ...
随机推荐
- ant 具体命令行展示代码
C:\Users\xutianhao>ant -hant [options] [target [target2 [target3] ...]]Options: -help, -h print t ...
- Linux下Nginx+tomcat应用系统性能优化
软件环境及服务器配置如下: Linux rh6.3,Tomcat7.0.29,Nginx1.2.7 mysql5.1,jdk1.6.0 mysql5.1 memcached 1.4.15 Xeno 2 ...
- DP HDIJ1421 搬宿舍
Problem Description 搬寝室是很累的,xhd深有体会.时间追述2006年7月9号,那天xhd迫于无奈要从27号楼搬到3号楼,因为10号要封楼了.看着寝室里的n件物品,xhd开始发呆, ...
- android handler looper thread
在线程中调用包含创建handler方法的时候,会报错,提示: “need call Looper.prepare()” -- 在创建之前,调用Looper.prepare()方法来创建一个looper ...
- 使用jQuery的attr方法来修改onclick值
这篇文章主要介绍了通过jQuery的attr修改onclick值的解决方法 ,需要的朋友可以参考下 var js = "alert('B:' + this.id); return false ...
- JMS开源比较
Java开源JMS消息中间件 mom4j mom4j是一个完全实现JMS1.1规范的消息中间件并且向下兼容JMS1.0与1.02.它提供了自己的消息处理存储使它独立于关系数据与语言,所以它的客户端可以 ...
- VS2008查看dll导出函数
打开Visual Studio 2008 命令提示,使用命令 [plain] view plaincopyprint? dumpbin /exports simple.dll 即可查看
- dsdfdsfd
aibang.com/show/1816725179-1268699976/product/7069113.html aibang.com/show/1816725179-1268699976/pro ...
- 在vc中使用xtremetoolkit界面库-----安装及环境配置
近期想用一下xtremetoolkitPro界面库.网上的使用教程资源也不多,当中着实遇到了很多的困难,毕竟是首次使用. 首先当然是配置发开环境了: 我使用的是vc6.0+xtremetoolkitP ...
- opencv视频播放
在一个界面上显示一张图片.是一件非常easy的事情,但说到要显示视频.刚開始学习的人可能不知道怎么处理,事实上,一般来说能够理解为视频就是图片以人眼察觉不到的速度高速更新. 曾经用摄像头採集视频显示在 ...