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

相关文章

Java JUC并发集合详解之线程安全容器完全攻略

《JavaJUC并发集合详解之线程安全容器完全攻略》Java通过java.util.concurrent(JUC)包提供了一整套线程安全的并发容器,它们不仅是简单的同步包装,更是基于精妙并发算法构建... 目录一、为什么需要JUC并发集合?二、核心并发集合分类与详解三、选型指南:如何选择合适的并发容器?在多

python语言中的常用容器(集合)示例详解

《python语言中的常用容器(集合)示例详解》Python集合是一种无序且不重复的数据容器,它可以存储任意类型的对象,包括数字、字符串、元组等,下面:本文主要介绍python语言中常用容器(集合... 目录1.核心内置容器1. 列表2. 元组3. 集合4. 冻结集合5. 字典2.collections模块

Spring Boot中获取IOC容器的多种方式

《SpringBoot中获取IOC容器的多种方式》本文主要介绍了SpringBoot中获取IOC容器的多种方式,包括直接注入、实现ApplicationContextAware接口、通过Spring... 目录1. 直接注入ApplicationContext2. 实现ApplicationContextA

linux配置podman阿里云容器镜像加速器详解

《linux配置podman阿里云容器镜像加速器详解》本文指导如何配置Podman使用阿里云容器镜像加速器:登录阿里云获取专属加速地址,修改Podman配置文件并移除https://前缀,最后拉取镜像... 目录1.下载podman2.获取阿里云个人容器镜像加速器地址3.更改podman配置文件4.使用po

k8s容器放开锁内存限制问题

《k8s容器放开锁内存限制问题》nccl-test容器运行mpirun时因NCCL_BUFFSIZE过大导致OOM,需通过修改docker服务配置文件,将LimitMEMLOCK设为infinity并... 目录问题问题确认放开容器max locked memory限制总结参考:https://Access

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与