How Long Does It Take (25分)【C语言】AOE拓扑排序

2024-04-23 16:38
文章标签 语言 25 排序 long 拓扑 take aoe

本文主要是介绍How Long Does It Take (25分)【C语言】AOE拓扑排序,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 题目:
    • 输入格式
    • 输出格式
    • 输入样例
    • 输出样例
  • 算法
    • AOE拓扑排序
      • 代码实现
        • AOE函数
        • 邻接矩阵存储的图

习题讲解视频

题目:

Given the relations of all the activities of a project, you are supposed to find the earliest completion time of the project.

输入格式

Each input file contains one test case. Each case starts with a line containing two positive integers N (≤100), the number of activity check points (hence it is assumed that the check points are numbered from 0 to N−1), and M, the number of activities. Then M lines follow, each gives the description of an activity. For the i-th activity, three non-negative numbers are given: S[i], E[i], and L[i], where S[i] is the index of the starting check point, E[i] of the ending check point, and L[i] the lasting time of the activity. The numbers in a line are separated by a space.

输出格式

For each test case, if the scheduling is possible, print in a line its earliest completion time; or simply output “Impossible”.

输入样例

9 12
0 1 6
0 2 4
0 3 5
1 4 1
2 4 1
3 5 2
5 4 0
4 6 9
4 7 7
5 7 4
6 8 2
7 8 4

输出样例

18

算法

AOE拓扑排序

  • 入度为0的结点全部压入队列(如果是单一起点,压入指点结点即可)
  • while循环中弹出一个结点,对此节点的邻结点的入度减一(如果此邻结点入度减为0则直接入队)同时,更新此结点的earliest
  • 根据处理的结点总数判断时间安排是否合理。合理时,在所有结点中选择最大的earliest输出

代码实现

int main()
{	int N,E;scanf("%d %d",&N,&E);Graph G=CreateGraph(N);BuildGraph(G,E);AOE(G);return 0;
}
AOE函数
  • 入度为0的结点全部压入队列(如果是单一起点,压入指点结点即可)
  • while循环中弹出一个结点,对此节点的邻结点的入度减一(如果此邻结点入度减为0则直接入队)同时,更新此结点的earliest
  • 根据处理的结点总数判断时间安排是否合理。合理时,在所有结点中选择最大的earliest输出
void AOE(Graph G)
{int *earliest=(int*)malloc(sizeof(int)*(G->VertexNum));//记录每个结点完成的最早时间 int *indegree=(int*)malloc(sizeof(int)*(G->VertexNum));//记录每个结点的入度 int i,j;for(i=0;i<G->VertexNum;i++){//初始化earliest,indegreeearliest[i]=-1;indegree[i]=0;for(j=0;j<G->VertexNum;j++){if(G->GraphMatrix[j][i]!=-1){indegree[i]++;}}}int *Queue=(int*)malloc(sizeof(int)*(G->VertexNum+1));int rear=0,head=0;int count=0;//当前收录到集合中元素个数 for(i=0;i<G->VertexNum;i++){//收录初始入度为0的结点if(indegree[i]==0){ Queue[rear++]=i;earliest[i]=0;}}int t,MaxVertex;while(rear>head){t=Queue[head++];count++;for(i=0;i<G->VertexNum;i++){if((G->GraphMatrix[t][i]!=-1)){if(--indegree[i]==0){Queue[rear++]=i;}if(earliest[i]<earliest[t]+G->GraphMatrix[t][i]){earliest[i]=earliest[t]+G->GraphMatrix[t][i];} }} }if(count==G->VertexNum){int MaxSchedule=0;for(i=0;i<G->VertexNum;i++){if(earliest[i]>MaxSchedule){MaxSchedule=earliest[i];}}printf("%d",MaxSchedule);}else{printf("Impossible");}
}
邻接矩阵存储的图
#define MAXVERTEXNUM 101
typedef struct GNode* Graph;
struct GNode{int VertexNum;int EdgeNum;int GraphMatrix[MAXVERTEXNUM][MAXVERTEXNUM];
};
typedef struct ENode* edge;
struct ENode{int V;int W;int Weight;
};
Graph CreateGraph(int N)
{Graph G=(Graph)malloc(sizeof(struct GNode));G->VertexNum=N;int i,j;for(i=0;i<N;i++){for(j=0;j<N;j++){G->GraphMatrix[i][j]=-1;}}return G;
}
void InsertEdge(Graph G,edge L)
{G->GraphMatrix[L->V][L->W]=L->Weight;
}
void BuildGraph(Graph G,int E)
{G->EdgeNum=E;edge L=(edge)malloc(sizeof(struct ENode));int i;for(i=0;i<E;i++){scanf("%d %d %d",&(L->V),&(L->W),&(L->Weight));InsertEdge(G,L);}free(L);
}

这篇关于How Long Does It Take (25分)【C语言】AOE拓扑排序的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

Spring排序机制之接口与注解的使用方法

《Spring排序机制之接口与注解的使用方法》本文介绍了Spring中多种排序机制,包括Ordered接口、PriorityOrdered接口、@Order注解和@Priority注解,提供了详细示例... 目录一、Spring 排序的需求场景二、Spring 中的排序机制1、Ordered 接口2、Pri

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

Go语言利用泛型封装常见的Map操作

《Go语言利用泛型封装常见的Map操作》Go语言在1.18版本中引入了泛型,这是Go语言发展的一个重要里程碑,它极大地增强了语言的表达能力和灵活性,本文将通过泛型实现封装常见的Map操作,感... 目录什么是泛型泛型解决了什么问题Go泛型基于泛型的常见Map操作代码合集总结什么是泛型泛型是一种编程范式,允

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

大数据小内存排序问题如何巧妙解决

《大数据小内存排序问题如何巧妙解决》文章介绍了大数据小内存排序的三种方法:数据库排序、分治法和位图法,数据库排序简单但速度慢,对设备要求高;分治法高效但实现复杂;位图法可读性差,但存储空间受限... 目录三种方法:方法概要数据库排序(http://www.chinasem.cn对数据库设备要求较高)分治法(常

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3