Day4 - G - 确定比赛名次 HDU - 1285
Input输入有若干组,每组中的第一行为二个数N(1<=N<=500),M;其中N表示队伍的个数,M表示接着有M行的输入数据。接下来的M行数据中,每行也有两个整数P1,P2表示即P1队赢了P2队。
Output给出一个符合要求的排名。输出时队伍号之间有空格,最后一名后面没有空格。
其他说明:符合条件的排名可能不是唯一的,此时要求输出时编号小的队伍在前;输入数据保证是正确的,即输入数据确保一定能有一个符合要求的排名。
Sample Input
4 3
1 2
2 3
4 3
Sample Output
1 2 4 3 思路:直接拓扑排序即可,输出要求字典序最小,那么DFS就不行,无法保证字典序,直接上优先队列,代码如下:
插一手DFS代码(无字典序)
const int maxm = ; int G[maxm][maxm], vis[maxm], N, M;
vector<int> ans; bool dfs(int x) {
vis[x] = -;
for (int i = ; i <= N; ++i) {
if(G[x][i]) {
if(vis[i] == -)
return false;
if(!vis[i] && !dfs(i))
return false;
}
}
vis[x] = ;
ans.push_back(x);
return true;
} int main() {
while(scanf("%d%d",&N,&M) != EOF) {
memset(G, , sizeof(G)), ans.clear(), memset(vis, , sizeof(vis));
for (int i = ; i < M; ++i) {
int t1,t2;
scanf("%d%d", &t1, &t2);
G[t1][t2] = ;
}
for(int i = ; i <= N; ++i)
if(!vis[i])
if(!dfs(i))
break;
int cnt = ;
for (auto i = ans.rbegin(); i != ans.rend(); ++i) {
if(cnt++)
printf(" ");
printf("%d", *i);
if(cnt == N)
break;
}
}
return ;
}
AC代码:
const int maxm = ;
int N, M, in[maxm], G[maxm][maxm], ans[maxm], cnt;
struct Node {
int id;
Node(int _id) : id(_id){}
bool operator<(const Node &a) const {
return a.id < id;
}
};
int main() {
while(scanf("%d%d", &N, &M) != EOF) {
memset(in, , sizeof(in)), memset(G, , sizeof(G)), cnt = ;
for (int i = ; i < M; ++i) {
int t1, t2;
scanf("%d%d", &t1, &t2);
if(!G[t1][t2]) {
G[t1][t2] = ;
in[t2]++;
}
}
priority_queue<Node> q;
for (int i = ; i <= N; ++i) {
if(!in[i])
q.push(Node(i));
}
while(!q.empty()) {
Node p = q.top();
q.pop();
int u = p.id;
ans[cnt++] = u;
for (int i = ; i <= N; ++i) {
if(G[u][i]) {
if(!--in[i])
q.push(Node(i));
}
}
}
for(int i = ; i < N; ++i) {
if(i)printf(" ");
printf("%d", ans[i]);
}
printf("\n");
}
return ;
}
注意读入判重,否则会影响入度的计算。
Day4 - G - 确定比赛名次 HDU - 1285的更多相关文章
- (拓扑)确定比赛名次 -- hdu -- 1285
http://acm.hdu.edu.cn/showproblem.php?pid=1285 确定比赛名次 Time Limit: 2000/1000 MS (Java/Others) Memo ...
- 确定比赛名次 HDU - 1285 (拓扑排序)
注意点: 输入数据中可能有重复,需要进行处理! #include <stdio.h> #include <iostream> #include <cstring> ...
- ACM: HDU 1285 确定比赛名次 - 拓扑排序
HDU 1285 确定比赛名次 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u De ...
- HDU.1285 确定比赛名次 (拓扑排序 TopSort)
HDU.1285 确定比赛名次 (拓扑排序 TopSort) 题意分析 裸的拓扑排序 详解请移步 算法学习 拓扑排序(TopSort) 只不过这道的额外要求是,输出字典序最小的那组解.那么解决方案就是 ...
- hdu oj 1285 确定比赛名次
hdu oj 1285 确定比赛名次 题目: 确定比赛名次 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K ...
- HDU 1285 确定比赛名次
传送门 确定比赛名次 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total ...
- 正向与反向拓扑排序的区别(hdu 1285 确定比赛名次和hdu 4857 逃生)
确定比赛名次 Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submis ...
- hdu 1285 确定比赛名次 (拓扑)
确定比赛名次 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Subm ...
- HDU 1285 确定比赛名次【字典序最小的拓扑排序 + 优先队列】
确定比赛名次 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...
随机推荐
- 1.ORM介绍,基本配置及通过ORM框架创建表
1.介绍 ORM全拼Object-Relation Mapping(对象-关系映射) 作用:主要实现模型对象到关系数据库数据的映射 通过ORM框架作为一个中间者或者是一个桥梁,开发者通过定义模型类,属 ...
- lua叠代器
注意:叠待值遇到nil就退出 叠代器,是符合for遍历框架,需要满足条件 1-叠代函数,常量,控制变量 2-叠代函数可以接受二个参数,当然也可以忽略处理(利用闭包封装参数作为控制变量和状态变量) 无状 ...
- B: 最小代价
B: 最小代价 题解:先用最小生成树求联通所有点的最小代价ans 在求度为1的时候权值最大的点mx ans-mx就是答案 #include<iostream> #include<al ...
- tensorflow中的Fetch、Feed(02-3)
import tensorflow as tf #Fetch概念 在session中同时运行多个op input1=tf.constant(3.0) #constant()是常量不用进行init初始化 ...
- 1 (msql实战) 基础架构
mysql> select * from T where ID=10: 我们看到的只是输入一条语句,返回一个结果,却不知道这条语句在 MySQL 内部的执行过程. 所以今天我想和你一起把 MyS ...
- 从系统引导菜单禁用Hyper-V
1, 从当前引导运行的系统复制一个新引导菜单项: bcdedit /copy {current} /d "Win10 NO_HV" 这时候cmd会输出新引导项的 guid, 复制出 ...
- HTTP关键词收集
[HTTP协议][客户端][服务器端][HTTPS][Web服务器][域名][DNS][IP地址][虚拟服务器][虚拟主机][中转服务器][HTTP/1.1规范][域名解析][Web托管服务][代理] ...
- list的三个子类的特点
- scrapy(创建scrapy工程)报错:“ ImportError:DLL load failed:找不到指定的模块”
先要确定什么模块找不到 解决方法 windowa环境下加 ( --user) pip install -I cryptography --user
- pyhton的返回值
a=input() input()函数返回的是字符‘2’ a=bin(2) bin函数返回的是二进制形式的字符串'0b10' type()判断类型 bin()转化成二进制 int(a,2)可以强制把字 ...