洛谷 P1347 排序
题目描述
一个不同的值的升序排序数列指的是一个从左到右元素依次增大的序列,例如,一个有序的数列A,B,C,D 表示A<B,B<C,C<D。在这道题中,我们将给你一系列形如A<B的关系,并要求你判断是否能够根据这些关系确定这个数列的顺序。
输入输出格式
输入格式:
第一行有两个整数n,m,n表示需要排序的元素数量,2<=n<=26,第1到n个元素将用大写的A,B,C,D....表示。m表示将给出的形如A<B的关系的数量。
接下来有m行,每行有3个字符,分别为一个大写字母,一个<符号,一个大写字母,表示两个元素之间的关系。
输出格式:
若根据前x个关系即可确定这n个元素的顺序yyy..y(如ABC),输出
Sorted sequence determined after xxx relations: yyy...y.
若根据前x个关系即发现存在矛盾(如A<B,B<C,C<A),输出
Inconsistency found after 2 relations.
若根据这m个关系无法确定这n个元素的顺序,输出
Sorted sequence cannot be determined.
(提示:确定n个元素的顺序后即可结束程序,可以不用考虑确定顺序之后出现矛盾的情况)
输入输出样例
- 1:
- 4 6
- A<B
- A<C
- B<C
- C<D
- B<D
- A<B
- 2:
- 3 2
- A<B
- B<A
- 3:
- 26 1
- A<Z
- 1:
- Sorted sequence determined after 4 relations: ABCD.
- 2:
- Inconsistency found after 2 relations.
- 3:
- Sorted sequence cannot be determined.
————————————————我是分割线——————————————————-
- /*
- Problem:
- OJ:
- User:S.B.S.
- Time:
- Memory:
- Length:
- */
- #include<iostream>
- #include<cstdio>
- #include<cstring>
- #include<cmath>
- #include<algorithm>
- #include<queue>
- #include<cstdlib>
- #include<iomanip>
- #include<cassert>
- #include<climits>
- #include<functional>
- #include<bitset>
- #include<vector>
- #include<list>
- #include<map>
- #define maxn 100001
- #define F(i,j,k) for(int i=j;i<=k;i++)
- #define rep(i,j,k) for(int i=j;i<k;i++)
- #define M(a,b) memset(a,b,sizeof(a))
- #define FF(i,j,k) for(int i=j;i>=k;i--)
- #define inf 0x3f3f3f3f
- #define maxm 1001
- #define mod 998244353
- //#define LOCAL
- using namespace std;
- int read(){
- int x=,f=;char ch=getchar();
- while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
- while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
- return x*f;
- }
- void print(int n){
- if(n<){putchar('-');n=-n;}
- if(n>=) print(n/);
- putchar((n%)+'');
- return;
- }
- int n,m;
- int p[maxn],in[maxn],out[maxn];
- int tot,ans;
- vector<int> edge[maxn];
- char mp[];
- bool vis[maxn],cur[maxn];
- inline bool solve(int u)
- {
- // cout<<"in solve!"<<endl;
- vis[u]=true;
- for(register int i=edge[u].size()-;i>=;i--){
- int v=edge[u][i];
- if(vis[v]) return false;
- if(!solve(edge[u][i])) return false;
- }
- vis[u]=false;
- return true;
- }
- inline void dfs(int u,int sum,int id)
- {
- // cout<<"int dfs!!"<<endl;
- p[sum]=u;
- if(sum==n){
- cout<<"Sorted sequence determined after "<<id<<" relations: ";
- F(i,,n) cout<<(char)(p[i]+'A'-);
- cout<<"."<<endl;exit();
- }
- for(register int i=edge[u].size()-;i>=;i--) dfs(edge[u][i],sum+,id);
- }
- inline void ok(int u)
- {
- // cout<<"in ok !!!"<<endl;
- F(i,,n){
- if(cur[i]){
- M(vis,false);
- if(!solve(i)){
- cout<<"Inconsistency found after "<<u<<" relations."<<endl;
- exit();
- }
- }
- }
- if(tot!=n) return;
- F(i,,n) if(!in[i]) {dfs(i,,u);break;}
- }
- int main()
- {
- // std::ios::sync_with_stdio(false);//cout<<setiosflags(ios::fixed)<<setprecision(1)<<y;
- #ifdef LOCAL
- freopen("data.in","r",stdin);
- freopen("data.out","w",stdout);
- #endif
- n=read();m=read();
- F(i,,m){
- // cout<<"in main!!!!"<<endl;
- scanf("%s",mp);
- int a=mp[]-'A'+,b=mp[]-'A'+;
- out[a]++;in[b]++;
- if(!cur[a]) tot++;
- if(!cur[b]) tot++;
- cur[a]=cur[b]=true;
- edge[a].push_back(b);
- ok(i);
- }
- cout<<"Sorted sequence cannot be determined."<<endl;
- return ;
- }
洛谷 P1347 排序的更多相关文章
- 洛谷——P1347 排序
洛谷—— P1347 排序 题目描述 一个不同的值的升序排序数列指的是一个从左到右元素依次增大的序列,例如,一个有序的数列A,B,C,D 表示A<B,B<C,C<D.在这道题中,我们 ...
- 洛谷P1347 排序
这个题看到很多人写Topo排序,其实这道题第一眼看更像是一个差分约束的裸题QWQ... 令dis[x]表示x的相对大小(1是最小,n是最大),显然,对于一个关系A<B,我们有dis[A]< ...
- 【洛谷P1347】排序
题目大意:给定 N 个变量和 M 个变量之间的偏序关系,问能否求出这 N 个变量之间的一个全序.若能,输出最少利用多少条已知信息即可求的结果,且输出该全序:若无解,输出到第几条已知信息可以判定无解:若 ...
- 题解【洛谷P1347】排序
题目描述 一个不同的值的升序排序数列指的是一个从左到右元素依次增大的序列,例如,一个有序的数列\(A,B,C,D\) 表示\(A<B,B<C,C<D\).在这道题中,我们将给你一系列 ...
- 洛谷 P1347 【排序】
这篇题解没有用拓补排序 (嗐 菜就直说) 个人感觉这道题拓补排序没有变种\(Floyd\)好写吧,思维难度也低一点(亲眼目睹机房dalao这道题拓补排序调了很久). 吐槽结束,开始正题~ 对于这道题为 ...
- 洛谷P2824 排序
解:splay + 线段树合并,分裂. 首先有个乱搞做法是外层拿splay维护,有序区间缩成splay上一个节点.内层再开个数据结构支持合并分裂有序集合. 内层我一开始想的是splay,然后就没有复杂 ...
- 【题解】洛谷P1975排序
分块,注意重复的值之间的处理.跟普通分块的操作一样的啦,具体可以参见‘不勤劳的图书管理员’. #include <bits/stdc++.h> using namespace std; # ...
- 洛谷P3953 逛公园(NOIP2017)(最短/长路,拓扑排序,动态规划)
洛谷题目传送门 又是一年联赛季.NOIP2017至此收官了. 这个其实是比较套路的图论DP了,但是细节有点恶心. 先求出\(1\)到所有点的最短路\(d1\),和所有点到\(n\)的最短路\(dn\) ...
- 洛谷P4332 [SHOI2014]三叉神经树(LCT,树剖,二分查找,拓扑排序)
洛谷题目传送门 你谷无题解于是来补一发 随便百度题解,发现了不少诸如树剖\(log^3\)LCT\(log^2\)的可怕描述...... 于是来想想怎么利用题目的性质,把复杂度降下来. 首先,每个点的 ...
随机推荐
- Anaconda完全入门指南
Anaconda完全入门指南 参考文章: 致Python初学者:Anaconda入门使用指南 Anaconda使用总结 概述 很多学习python的初学者甚至学了有一段时间的人接触到anaconda或 ...
- 20172301 《Java软件结构与数据结构》实验二报告
20172301 <Java软件结构与数据结构>实验二报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 郭恺 学号:20172301 实验教师:王志强老师 ...
- Java中static块执行时机
Java中static块执行时机 演示例子 在使用static进行初始化的操作,怎么也执行不了!代码如下: public class StaticDemo { public static final ...
- 使用ApiPost测试接口时需要先登录怎么办?利用Cookie模拟登陆!
ApiPost简介: ApiPost是一个支持团队协作,并可直接生成文档的API调试.管理工具.它支持模拟POST.GET.PUT等常见请求,是后台接口开发者或前端.接口测试人员不可多得的工具 . 下 ...
- url后面添加参数,注意&?的添加方式
// 添加参数&key=value 直接输出url function insertParam(key, value) { key = encodeURI(key); value = encod ...
- Xamarin iOS教程之申请付费开发者账号下载证书
Xamarin iOS教程之申请付费开发者账号下载证书 Xamarin iOS使用真机测试应用程序 在讲解iOS Simulator时,已经提到了虽然iOS Simulator可以模仿真实的设备,但是 ...
- 1200 同余方程 2012年NOIP全国联赛提高组
题目描述 Description 求关于 x 同余方程 ax ≡ 1 (mod b)的最小正整数解. 输入描述 Input Description 输入只有一行,包含两个正整数 a, b,用 一个 空 ...
- java基础记录(一):开发环境的配置
一.JDK的安装与环境变量配置 1.jdk下载与安装. jdk1.8.0_192下载地址 下载完成后,双击运行安装文件.可以选择你要安装的位置或者直接下一步,等待安装完成,最后关闭. 2.配置环境变量 ...
- iOS 七牛多张图片上传
-(void)uploadImages:(NSArray *)images atIndex:(NSInteger)index token:(NSString *)token uploadManager ...
- 利用dynamic简化数据库的访问
今天写了一个数据库的帮助类,代码如下. public static class DbEx { public static dynamic ReadToObject(this IDataReader r ...