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

相关文章

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

Go语言中make和new的区别及说明

《Go语言中make和new的区别及说明》:本文主要介绍Go语言中make和new的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 概述2 new 函数2.1 功能2.2 语法2.3 初始化案例3 make 函数3.1 功能3.2 语法3.3 初始化

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

一文详解Java Stream的sorted自定义排序

《一文详解JavaStream的sorted自定义排序》Javastream中的sorted方法是用于对流中的元素进行排序的方法,它可以接受一个comparator参数,用于指定排序规则,sorte... 目录一、sorted 操作的基础原理二、自定义排序的实现方式1. Comparator 接口的 Lam

Go语言代码格式化的技巧分享

《Go语言代码格式化的技巧分享》在Go语言的开发过程中,代码格式化是一个看似细微却至关重要的环节,良好的代码格式化不仅能提升代码的可读性,还能促进团队协作,减少因代码风格差异引发的问题,Go在代码格式... 目录一、Go 语言代码格式化的重要性二、Go 语言代码格式化工具:gofmt 与 go fmt(一)

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个