POJ:1094-Sorting It All Out(拓扑排序经典题型)
Sorting It All Out
Time Limit: 1000MS Memory Limit: 10000K
Description
An ascending sorted sequence of distinct values is one in which some form of a less-than operator is used to order the elements from smallest to largest. For example, the sorted sequence A, B, C, D implies that A < B, B < C and C < D. in this problem, we will give you a set of relations of the form A < B and ask you to determine whether a sorted order has been specified or not.
Input
Input consists of multiple problem instances. Each instance starts with a line containing two positive integers n and m. the first value indicated the number of objects to sort, where 2 <= n <= 26. The objects to be sorted will be the first n characters of the uppercase alphabet. The second value m indicates the number of relations of the form A < B which will be given in this problem instance. Next will be m lines, each containing one such relation consisting of three characters: an uppercase letter, the character “<” and a second uppercase letter. No letter will be outside the range of the first n letters of the alphabet. Values of n = m = 0 indicate end of input.
Output
For each problem instance, output consists of one line. This line should be one of the following three:
Sorted sequence determined after xxx relations: yyy…y.
Sorted sequence cannot be determined.
Inconsistency found after xxx relations.
where xxx is the number of relations processed at the time either a sorted sequence is determined or an inconsistency is found, whichever comes first, and yyy…y is the sorted, ascending sequence.
Sample Input
4 6
A < B
A < C
B < C
C < D
B < D
A < B
3 2
A < B
B < A
26 1
A < Z
0 0
Sample Output
Sorted sequence determined after 4 relations: ABCD.
Inconsistency found after 2 relations.
Sorted sequence cannot be determined.
解题心得:
- 题意就是给你一系列的关系,让你从他给出的关系中从小到大排一个序,如果给出的关系中发生冲突,输出发生冲突的那一步,如果可以得到一个序,输出题目给出到第几个关系才能确定顺序。
- 其实就是给出一个关系,然后拓扑排序判断一下,因为最多只有26个字母,所以怎么写都不会超时。如果题目给出的关系发生冲突,那么必然可以形成环,所以判断环就行,如果能够确定n个点的关系,那么每次只能出现一个出度为0的点,最后n个点的顺序全得到。思路比较简单,只要不手贱写一些BUG那么还是很容易用代码实现的。
#include<stdio.h>
#include<algorithm>
#include<set>
#include<stack>
#include<vector>
#include<cstring>
using namespace std;
const int maxn = 100;
char s[maxn];
vector <int> ve[maxn];//用不定长数组来存储边的关系
int out[maxn],n,m;
bool vis[maxn],maps[maxn][maxn];
int ans;
stack <int> st1;
void init()
{
ans = -1;
for(int i=0; i<maxn; i++)
ve[i].clear();
memset(out,0,sizeof(out));
memset(maps,0,sizeof(maps));
memset(vis,0,sizeof(vis));
}
int toposort(int pos)
{
maps[s[0]][s[2]] = true;
vis[s[0]] = vis[s[2]] = true;//已经出现了的点
out[s[0]]++;//出度++
ve[s[2]].push_back(s[0]);
int in1[maxn],out1[maxn];
bool vis1[maxn];
memcpy(out1,out,sizeof(out));
memcpy(vis1,vis,sizeof(vis));
stack<int>st;
bool flag = false;
while(1)
{
int num = 0;
vector<int>va;
for(int i='A'; i<'A'+n; i++)
{
if(out1[i] == 0 && vis1[i])//出度为零并且已经出现了的点
va.push_back(i);
}
if(va.size() > 1)//出度为0的点不止一个做好标记
flag = true;
if(va.size() == 0)//没有出度为0的点了
break;
for(int i=0; i<va.size(); i++)//根据拓扑排序来解决这个出度为0的点
{
int k = va[i];
st.push(k);
vis1[k] = false;
for(int j=0;j<ve[k].size();j++)
out1[ve[k][j]]--;
}
}
int sum2 = 0;
for(int i='A'; i<'A'+n; i++)//检查是否出现了环
if(out1[i])
sum2++;
if(sum2 != 0)
{
//如果有环记录出现环的步数,然后直接返回
ans = pos;
return 2;
}
if(flag)//出现了多个入度为零的点
return 1;
if(st.size() == n)//找到了n个符合拓扑排序的点
{
ans = pos;
st1 = st;
return 3;
}
return 1;//给出的关系不够不能得出答案
}
int main()
{
while(scanf("%d%d",&n,&m) && n+m)
{
init();//初始化一些数组
bool cont_flag = false;//是否已经出现结果
int k;
for(int i=1; i<=m; i++)
{
scanf("%s",s);
if(cont_flag)
continue;
if(maps[s[0]][s[2]])//去除重边
continue;
k = toposort(i);
if(k == 2)
cont_flag = true;
if(k == 3)
cont_flag = true;
}
if(k != 3 && k != 2)//没找到答案也未出现环,说明给出的关系不足以判断
printf("Sorted sequence cannot be determined.\n");
if(k == 2)
printf("Inconsistency found after %d relations.\n",ans);
if(k == 3)
{
printf("Sorted sequence determined after %d relations: ",ans);
while(st1.size())
{
printf("%c",st1.top());
st1.pop();
}
printf(".\n");
}
}
return 0;
}
POJ:1094-Sorting It All Out(拓扑排序经典题型)的更多相关文章
- ACM: poj 1094 Sorting It All Out - 拓扑排序
poj 1094 Sorting It All Out Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%lld & ...
- poj 1094 Sorting It All Out (拓扑排序)
http://poj.org/problem?id=1094 Sorting It All Out Time Limit: 1000MS Memory Limit: 10000K Total Su ...
- [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 (拓扑排序) - from lanshui_Yang
Description An ascending sorted sequence of distinct values is one in which some form of a less-than ...
- poj 1094 Sorting It All Out_拓扑排序
题意:是否唯一确定顺序,根据情况输出 #include <iostream> #include<cstdio> #include<cstring> #include ...
- POJ 1094 Sorting It All Out 拓扑排序 难度:0
http://poj.org/problem?id=1094 #include <cstdio> #include <cstring> #include <vector& ...
- PKU 1094 Sorting It All Out(拓扑排序)
题目大意:就是给定一组字母的大小关系判断他们是否能组成唯一的拓扑序列. 是典型的拓扑排序,但输出格式上确有三种形式: 1.该字母序列有序,并依次输出: 2.判断该序列是否唯一: 3.该序列字母次序之间 ...
- POJ 1094 Sorting It All Out(拓扑排序+判环+拓扑路径唯一性确定)
Sorting It All Out Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 39602 Accepted: 13 ...
- [ACM] POJ 1094 Sorting It All Out (拓扑排序)
Sorting It All Out Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 26801 Accepted: 92 ...
随机推荐
- feign hystrix加仪表盘
Hystrix-dashboard是一款针对Hystrix进行实时监控的工具,通过Hystrix Dashboard我们可以在直观地看到各Hystrix Command的请求响应时间, 请求成功率等数 ...
- vuejs 学习旅程一
来上海快一年了,一直在东钿金融工作着,这一年来主要负责公司前期的房产评估微信平台,公司IT部也是刚刚成立,成立IT部门不仅仅只是维护房产评估微信,而是要做一个互金理财平台.于是我一年来的主要工作是负责 ...
- javascript结合nodejs实现多文件上传
前端文件上传功能比较依赖后端,所以第一步用nodejs实现一个供文件上传的功能接口. 因为本人对nodejs也是一知半解,所以刚开始的想法是像原始的ajax交互那样,获取上传文件的内容,然后再通过no ...
- SQL基本语法总结
#创建数据库 DROP DATABASE IF EXISTS 数据库名; CREATE DATABASE 数据库名; #展示所有的数据库: SHOW DATABASES; #查看某个数据库的定义信息: ...
- 【js类库AngularJs】学习angularJs的指令(包括常见表单验证,隐藏等功能)
[js类库AngularJs]学习angularJs的指令(包括常见表单验证,隐藏等功能) AngularJS诞生于2009年,由Misko Hevery 等人创建,后为Google所收购.是一款优秀 ...
- [论文理解] Rapid-Object-Detection-using-a-Boosted-cascade-of-simple-features
Rapid-Object-Detection-using-a-Boosted-cascade-of-simple-features 简介 文章是2001年发表的,是一篇很经典的Object Detec ...
- 2018.4.17 java多线程练习二模拟开场仪式进场
2.某公司组织年会,会议入场时有两个入口,在入场时每位员工都能获取一张双色球彩票,假设公司有100个员工,利用多线程模拟年会入场过程, 并分别统计每个入口入场的人数,以及每个员工拿到的彩票的号码.线程 ...
- 字符串 -----JavaScript
本文摘要:http://www.liaoxuefeng.com/ JavaScript的字符串就是用''或""括起来的字符表示. 如果'本身也是一个字符,那就可以用"&q ...
- 用C#(ASP.Net)在Exchange Server环境下发送邮件
普通的邮件, 用System.Net.Mail 类 或 System.Web.Mail 类 处理即可, 但是Exchange Server 环境下, 这两个类起不了作用-------至少目前我看到的情 ...
- Bootstrap 下拉菜单(dropdown)插件
使用下拉菜单的插件,您可以向任何组件(比如:导航栏,标签页,胶囊式导航,按钮)添加下拉菜单 用法 您可以切换下拉菜单(dropdown)插件隐藏内容 1.通过data属性,向链接或按钮添加data-t ...