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

相关文章

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import

oracle DBMS_SQL.PARSE的使用方法和示例

《oracleDBMS_SQL.PARSE的使用方法和示例》DBMS_SQL是Oracle数据库中的一个强大包,用于动态构建和执行SQL语句,DBMS_SQL.PARSE过程解析SQL语句或PL/S... 目录语法示例注意事项DBMS_SQL 是 oracle 数据库中的一个强大包,它允许动态地构建和执行

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

Go路由注册方法详解

《Go路由注册方法详解》Go语言中,http.NewServeMux()和http.HandleFunc()是两种不同的路由注册方式,前者创建独立的ServeMux实例,适合模块化和分层路由,灵活性高... 目录Go路由注册方法1. 路由注册的方式2. 路由器的独立性3. 灵活性4. 启动服务器的方式5.

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创