HDU 4857 逃生(拓扑排序,优先队列,容器)

2023-12-13 20:08

本文主要是介绍HDU 4857 逃生(拓扑排序,优先队列,容器),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

逃生

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 4142    Accepted Submission(s): 1148


Problem Description
糟糕的事情发生啦,现在大家都忙着逃命。但是逃命的通道很窄,大家只能排成一行。

现在有n个人,从1标号到n。同时有一些奇怪的约束条件,每个都形如:a必须在b之前。
同时,社会是不平等的,这些人有的穷有的富。1号最富,2号第二富,以此类推。有钱人就贿赂负责人,所以他们有一些好处。

负责人现在可以安排大家排队的顺序,由于收了好处,所以他要让1号尽量靠前,如果此时还有多种情况,就再让2号尽量靠前,如果还有多种情况,就让3号尽量靠前,以此类推。

那么你就要安排大家的顺序。我们保证一定有解。

Input
第一行一个整数T(1 <= T <= 5),表示测试数据的个数。
然后对于每个测试数据,第一行有两个整数n(1 <= n <= 30000)和m(1 <= m <= 100000),分别表示人数和约束的个数。

然后m行,每行两个整数a和b,表示有一个约束a号必须在b号之前。a和b必然不同。

Output
对每个测试数据,输出一行排队的顺序,用空格隔开。

Sample Input
  
1 5 10 3 5 1 4 2 5 1 2 3 4 1 4 2 3 1 5 3 5 1 2

Sample Output
  
1 2 3 4 5

Author
CLJ

Source
BestCoder Round #1

Recommend
We have carefully selected several similar problems for you:   5803  5802  5801  5800  5799 


思路:

跟着学姐的思路用的是邻接表,建立反向拓扑:

因为:输入3 1 应该是3 1  2,如果是按普通的正向拓扑排序做的就是2 在最前面 即 2  3  1(不正确)。


之前参考的是容器的思想:

第一次使用 vector 容器,之前宇神讲过一次(.......),看了会题解,敲了两个小时。

容器要看,优先队列还要去复习下微笑


代码:邻接表+优先队列

#include<stdio.h>
#include<string.h>
#include<queue>
const int MYDD=1103+1e5;
using namespace std;int head[MYDD];
int indegree[MYDD];
int numedge;//边数
struct EDGE {int v,next;
} edge[MYDD*2];void init() {//邻接表的初始化memset(head,-1,sizeof(head));memset(indegree,0,sizeof(indegree));numedge=0;
}void addedge(int a,int b) {EDGE T= {a,head[b]};edge[numedge]=T;head[b]=numedge++;
}int ans[MYDD];//记录排序顺序
void TopoSort(int x) {priority_queue<int> Q;//构造优先队列int now,dd=0;//当前节点,ans[]数组下标for(int j=1; j<=x; j++)if(!indegree[j])        Q.push(j);while(!Q.empty()) {now=Q.top();//队首元素Q.pop();//少了这句导致死循环ans[dd++]=now;for(int j=head[now]; j!=-1; j=edge[j].next) {int v=edge[j].v;indegree[v]--;if(!indegree[v])        Q.push(v);}
//		printf("%%%%%%%%%%\n");}
}int main() {int t;scanf("%d",&t);while(t--) {int n,m;scanf("%d%d",&n,&m);init();//初始化邻接表while(m--) {int a,b;scanf("%d%d",&a,&b);addedge(a,b);indegree[a]++;//目的是反向拓扑的计算}TopoSort(n);
//		printf("*******\n");for(int j=n-1; j>0; j--)      printf("%d ",ans[j]);printf("%d\n",ans[0]);}return 0;
}



vector 容器的讲解>>>>>博客园

代码实现2:容器+优先队列

参考CSDN

#include<stdio.h>
#include<string.h>
#include<vector>
#include<queue>
const int MYDD=1103;
const int MAXDD=1e5;
using namespace std;int edgenum;//边的标号
int head[MAXDD];//节点"头指针"
int indegree[MAXDD];//节点入度数
void init() {edgenum=0;memset(head,-1,sizeof(head));memset(indegree,0,sizeof(indegree));
}struct EDGE {int u,v,w,next;
} edge[MAXDD*2];
void addedge(int u,int v,int w) {EDGE T= {u,v,w,head[u]};edge[edgenum]=T;head[u]=edgenum++;
}vector<int> V;//构造容器
void Topo(int x) {V.clear();//清空容器priority_queue<int> Q;//定义优先队列while(!Q.empty())	Q.pop();//清空队列for(int j=1; j<=x; j++)if(indegree[j]==0)	Q.push(j);while(!Q.empty()) {int now=Q.top();Q.pop();for(int j=head[now]; j!=-1; j=edge[j].next) {int temp=edge[j].v;indegree[temp]--;if(indegree[temp]==0)		Q.push(temp);}V.push_back(now);//容器尾部插入数字}
}int main() {int t;scanf("%d",&t);while(t--) {init();int n,m;scanf("%d%d",&n,&m);while(m--) {int a,b;scanf("%d%d",&a,&b);addedge(b,a,1);//键入反了(其实也就是反向拓扑),看了好久 indegree[a]++;}Topo(n);for(int j=n-1; j>=1; j--)	printf("%d ",V[j]);printf("%d\n",V[0]);}return 0;
}

后:

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


这篇关于HDU 4857 逃生(拓扑排序,优先队列,容器)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringKafka错误处理(重试机制与死信队列)

《SpringKafka错误处理(重试机制与死信队列)》SpringKafka提供了全面的错误处理机制,通过灵活的重试策略和死信队列处理,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录引言一、Spring Kafka错误处理基础二、配置重试机制三、死信队列实现四、特定异常的处理策略五

如何高效移除C++关联容器中的元素

《如何高效移除C++关联容器中的元素》关联容器和顺序容器有着很大不同,关联容器中的元素是按照关键字来保存和访问的,而顺序容器中的元素是按它们在容器中的位置来顺序保存和访问的,本文介绍了如何高效移除C+... 目录一、简介二、移除给定位置的元素三、移除与特定键值等价的元素四、移除满足特android定条件的元

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

如何将Tomcat容器替换为Jetty容器

《如何将Tomcat容器替换为Jetty容器》:本文主要介绍如何将Tomcat容器替换为Jetty容器问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat容器替换为Jetty容器修改Maven依赖配置文件调整(可选)重新构建和运行总结Tomcat容器替

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque