CodeForces875C[拓扑排序] Codeforces Round #440 [Div2E/Div1C]
只要保存每相邻两行字符串 第一个不同位 即可。然后按照 第一个不同位上的字符有: " 来自下一行的 大于 来自上一行的" 构图,跑拓扑排序即可。
当然要判断一下有没有环构成, 有环一定是NO(可以思考一下)。
还可以提前判断下一行是不是上一行的前缀, 如果是,那么一定是NO。
在拓扑排序的过程中保存答案。
比如说对于 test9 :
10 10
8 1 1 6 10 2 2 9 7
6 2 7 1 9 5 10
1 5
7 3 6 9 6 3 7 6
10 3 9 10 3 6 7 10 6 9 6
10 4 4 9 8 2 10 3 6 2 9
8 4 8 6 4 6 4 8 6
2 7 5
6 8 6 2 1 9 8
3 10 2 10
可以得到相互关系:2 > 1,5 > 2,3 > 5,9 > 6,4 > 3,8 > 4,7 > 4,8 > 7,10 > 8。 在进行拓扑排序的过程中, 如果发现需要 2>3 这种情况时, 就要给3打上标记 , 在代码中我使用一个 f[3] 代表 3的实际值, 当3被
标记时, 直接 -2000000,以方便比较。
当然,如果在比较时发现,就算后面的元素加上了标记,依旧大于前面的 (f[v]>f[u]),此时直接No(这也意味着两个元素都被标记了);
#include <bits/stdc++.h>
using namespace std;
const int N = ;
int n, m, t, tt;
bool mark[N];
vector<int> a[N];
vector<int> b;
vector<int> G[N];
int f[N], in[N];
void out() {
puts("No");
exit();
}
void solve() {
for (int i = ; i <= m; i++) f[i] = i + ;//类似于一个映射函数,方便比较
for (int i = ; i < n; i++) {
bool flag = true;
int len = min(a[i - ].size(), a[i].size());
for (int j = ; j < len; j++) {
if (a[i - ][j] != a[i][j]) {
G[a[i][j]].push_back(a[i - ][j]);
in[a[i - ][j]]++;
flag = false;
break;
}
}
if (flag && a[i - ].size() > a[i].size()) {
out();//后一个是前一个的前缀
}
}
int cnt = ;
//拓扑排序开始
queue<int>q;
for (int i = ; i <= m; i++) {
if (in[i] == ) {
cnt++;
q.push(i);
}
}
while (!q.empty()) {
int u = q.front();
q.pop();
for (int i = ; i < G[u].size(); i++) {
int v = G[u][i];
in[v]--;
if (f[v] > f[u]) {
f[v] -= ; //等于加了个标记
mark[v] = true;
if (f[v] > f[u]) out(); //如果加了标记以后,还是小,那么NO
b.push_back(v);
}
if (!in[v]) {
cnt++;
q.push(v);
}
}
}
//拓扑排序结束
if (cnt < m) out(); //判断是不是所有元素的拓扑序都被判定了(判环)
puts("Yes");
cout << b.size() << endl;
for (int i = ; i < b.size(); i++) {
cout << b[i] << ' ';
} puts("");
}
int main() {
scanf("%d%d", &n, &m);
for (int i = ; i < n; i++) {
scanf("%d", &t);
for (int j = ; j < t; j++) {
scanf("%d", &tt);
a[i].push_back(tt);
}
}
solve();
return ;
}
CodeForces875C[拓扑排序] Codeforces Round #440 [Div2E/Div1C]的更多相关文章
- 拓扑排序 Codeforces Round #290 (Div. 2) C. Fox And Names
题目传送门 /* 给出n个字符串,求是否有一个“字典序”使得n个字符串是从小到大排序 拓扑排序 详细解释:http://www.2cto.com/kf/201502/374966.html */ #i ...
- Codeforces Round #440 (Div. 2)【A、B、C、E】
Codeforces Round #440 (Div. 2) codeforces 870 A. Search for Pretty Integers(水题) 题意:给两个数组,求一个最小的数包含两个 ...
- HDU4857——逃生(反向建图+拓扑排序)(BestCoder Round #1)
逃生 Description 糟糕的事情发生啦,现在大家都忙着逃命.但是逃命的通道很窄,大家只能排成一行. 现在有n个人,从1标号到n.同时有一些奇怪的约束条件,每个都形如:a必须在b之前.同时,社会 ...
- codeforces Round #440 A Search for Pretty Integers【hash/排序】
A. Search for Pretty Integers [题目链接]:http://codeforces.com/contest/872/problem/A time limit per test ...
- Codeforces Round #440 (Div. 2, based on Technocup 2018 Elimination Round 2)
A. Search for Pretty Integers 题目链接:http://codeforces.com/contest/872/problem/A 题目意思:题目很简单,找到一个数,组成这个 ...
- Codeforces Round #440 (Div. 2, based on Technocup 2018 Elimination Round 2) D. Something with XOR Queries
地址:http://codeforces.com/contest/872/problem/D 题目: D. Something with XOR Queries time limit per test ...
- [日常] Codeforces Round #440 Div.2 大力翻车实况
上次打了一发ABC然后大力翻车...上午考试又停电+Unrated令人非常滑稽...下午终于到了CF比赛... 赛前大力安利了一发然后拉了老白/ $ljm$ / $wcx$ 一起打, 然后搞了个 TI ...
- Codeforces Round #440 Div. 1
A:显然应该尽量拆成4.如果是奇数,先拆一个9出来即可. #include<iostream> #include<cstdio> #include<cmath> # ...
- Codeforces Round #440 (Div. 2) A,B,C
A. Search for Pretty Integers time limit per test 1 second memory limit per test 256 megabytes input ...
随机推荐
- IOS 响应者链条 and UIGestureRecognizer 手势识别器)
一次完整的触摸事件的传递响应的过程 UIAppliction --> UIWiondw -->递归找到最适合处理事件的控件 控件调用touches方法-->判断是否实现touches ...
- 【BZOJ2733】[HNOI2012] 永无乡(启发式合并Splay)
点此看题面 大致题意: 给你一张图,其中每个点有一个权值,有两种操作:在两点之间连一条边,询问一个点所在联通块第\(k\)小的权值. 平衡树 看到第\(k\)小,应该不难想到平衡树. 为了练习\(Sp ...
- 【转帖】Linux mount 域控权限的共享目录
https://www.linuxidc.com/Linux/2012-09/71388.htm 之前一直以为没法 映射 home 域的内容 其实还有一个地方.. 注意 空格的话 需要用 \ 进行转移 ...
- CUDA开发:了解设备属性
原文链接 今天介绍一下CUDA设备的相关属性,只有熟悉了硬件是相关属性,是怎么工作的,就能写出更适合硬件工作的代码.cudaDeviceProp这个结构体记录了设备的相关属性. struct cuda ...
- 10个HTML5 实战教程 提升你的综合开发能力
HTML5 作为下一代网站开发技术,无论你是一个 Web 开发人员或者想探索新的平台的游戏开发者,都值得去研究.借助尖端功能,技术和 API,HTML5 允许你创建响应性.创新性.互动性以及令人惊叹的 ...
- Bootstrap 历练实例 - 折叠(Collapse)插件事件
事件 下表列出了折叠(Collapse)插件中要用到的事件.这些事件可在函数中当钩子使用. 事件 描述 实例 show.bs.collapse 在调用 show 方法后触发该事件. $('#ident ...
- z-index、absolute、marquee滚动条的问题
1.z-index 层次叠加 ,元素叠加,谁的权重大谁就在上面 1).父级出现position:relation:的时候,失效: 2).层叠元素出现float的时候失效: 3).层次元素也得设置pos ...
- 自己写一个Promise
参考Promise 的 官方规范 https://promisesaplus.com/ Promise 其实就是一个状态机 它只有两种状态变化 pending => fulfill ...
- GNU汇编程序框架
汇编的作用:1.对芯片进行初始化 2. 和C混合编程提升C的运行效率 .section .data < 初始化的数据> .section .bss <未初始化的数据> .sec ...
- matplotlib(二)——matplotlib控制坐标轴第一个刻度到原点距离
一.问题描述 具体问题是: 用python库matplotlib进行数据的图表展示: 横坐标是自定义统计值: 保存矢量图(svg),保存后发现横坐的第一个点离坐标原点距离较大,导致图形离y轴较远,让画 ...