HDU 1285 确定比赛名次(拓扑排序的三种实现方法)

2023-12-13 20:08

本文主要是介绍HDU 1285 确定比赛名次(拓扑排序的三种实现方法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

确定比赛名次

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 22189    Accepted Submission(s): 8925


Problem Description
有N个比赛队(1<=N<=500),编号依次为1,2,3,。。。。,N进行比赛,比赛结束后,裁判委员会要将所有参赛队伍从前往后依次排名,但现在裁判委员会不能直接获得每个队的比赛成绩,只知道每场比赛的结果,即P1赢P2,用P1,P2表示,排名时P1在P2之前。现在请你编程序确定排名。

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

Author
SmallBeer(CML)

Source
杭电ACM集训队训练赛(VII)

Recommend
lcy   |   We have carefully selected several similar problems for you:   2647  3342  1811  1548  1874 



简单的拓扑排序模板题目。


代码:二维数组实现

#include<stdio.h>
#include<string.h>
#include<queue>
#include<stack>
using namespace std;
const int MYDD=1103;
const int MAXDD=512;int ANS[MYDD];//存储答案
int indegree[MAXDD];
int map[MAXDD][MAXDD];
void Topo(int x) {//拓扑排序二维数组int now;//记录当前入度为 0 的节点int t=1;for(int i=1; i<=x; i++) {for(int j=1; j<=x; j++) {if(!indegree[j]) {now=j;break;}}ANS[t++]=now;indegree[now]=-1;//防止重复遍历for(int j=1; j<=x; j++) {if(map[now][j])indegree[j]--;//将前驱中含有第 now 名点的前驱数量减1}}
}int main() {int n,m;while(scanf("%d%d",&n,&m)!=EOF) {memset(indegree,0,sizeof(indegree));memset(map,0,sizeof(map));while(m--) {int a,b;scanf("%d%d",&a,&b);if(!map[a][b]) { //防止重复性的输入数据map[a][b]=1;indegree[b]++;}}Topo(n);for(int j=1; j<=n-1; j++)printf("%d ",ANS[j]);printf("%d\n",ANS[n]);}return 0;
}


代码:邻接表的实现(没有初始化,导致错误一次)

#include<stdio.h>
#include<string.h>
const int MYDD=1103;
const int MAXDD=5120;int indegree[MYDD];//保存节点入度
int edgenum;//边的总数
int head[MYDD];//标记节点"头指针"
void init() {memset(head,-1,sizeof(head));memset(indegree,0,sizeof(indegree));edgenum=0;
}
struct EDGE {//边的信息int v,next;
} edge[MAXDD*8];void addedge(int a,int b) {//边的增加EDGE T= {b,head[a]};edge[edgenum]=T;head[a]=edgenum++;indegree[b]++;
}int ANS[MAXDD];
void Topo(int x) {//构造排序int now,t=1;for(int j=1; j<=x; j++) {for(int i=1; i<=x; i++) {if(!indegree[i]) {now=i;break;}}ANS[t++]=now;indegree[now]=-1;for(int i=head[now]; i!=-1; i=edge[i].next) {int temp=edge[i].v;indegree[temp]--;}}
}int main() {int n,m;while(scanf("%d%d",&n,&m)!=EOF) {init();while(m--) {int a,b;scanf("%d%d",&a,&b);addedge(a,b);}Topo(n);//进行拓扑排序for(int j=1; j<=n-1; j++)//输出结果printf("%d ",ANS[j]);printf("%d\n",ANS[n]);}return 0;
}

代码:优先队列的实现

#include<stdio.h>
#include<string.h>
#include<queue>
#include<functional>
using namespace std;
const int MYDD=1103;
const int MAXDD=512;int indegree[MAXDD];//保存节点入度
int map[MAXDD][MAXDD];
int ans[MAXDD];
//优先队列的实现 
void Topo(int x) {priority_queue<int,vector<int>,greater<int> > Q;if(!Q.empty())Q.pop();//队列的清空for(int j=1; j<=x; j++) {if(!indegree[j]) Q.push(j);}int dd=1;while(!Q.empty()) {//队列非空持续进行 int now=Q.top();//取出当前排名 Q.pop();indegree[now]=-1;ans[dd++]=now;for(int j=1; j<=x; j++) {if(map[now][j]) {indegree[j]--;//和当前排名有关联的节点度数 -1 if(!indegree[j])Q.push(j);}}}
}int main() {int n,m;while(scanf("%d%d",&n,&m)!=EOF) {memset(indegree,0,sizeof(indegree));memset(map,0,sizeof(map));while(m--) {int a,b;scanf("%d%d",&a,&b);if(!map[a][b])map[a][b]=1,indegree[b]++;}Topo(n);//进行拓扑排序for(int j=1; j<n; j++)//输出结果printf("%d ",ans[j]);printf("%d\n",ans[n]);}return 0;
}



后:

话说,学姐讲的不是很快,挺好的微笑

********************************************


这篇关于HDU 1285 确定比赛名次(拓扑排序的三种实现方法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/489800

相关文章

Redis客户端连接机制的实现方案

《Redis客户端连接机制的实现方案》本文主要介绍了Redis客户端连接机制的实现方案,包括事件驱动模型、非阻塞I/O处理、连接池应用及配置优化,具有一定的参考价值,感兴趣的可以了解一下... 目录1. Redis连接模型概述2. 连接建立过程详解2.1 连php接初始化流程2.2 关键配置参数3. 最大连

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

PyCharm中配置PyQt的实现步骤

《PyCharm中配置PyQt的实现步骤》PyCharm是JetBrains推出的一款强大的PythonIDE,结合PyQt可以进行pythion高效开发桌面GUI应用程序,本文就来介绍一下PyCha... 目录1. 安装China编程PyQt1.PyQt 核心组件2. 基础 PyQt 应用程序结构3. 使用 Q

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库