学妹,你要的C语言版AOE网络数据结构来了,就这么简单!

文章目录

  • AOE关键路径编程
  • AOE完整求解程序

AOE关键路径编程

在这里插入图片描述
不难发现AOE图最大特点是没有回路,并且有向图方向始终是从源点走向汇点,且源点汇点都是一个。

把图1写成邻接矩阵文件,见文件P200G736.TXT,并在此复制G0.C到AOE.C,修改这个程序的读文件名称,使其正确读出该文件的数据并构造图。

分析图1可知,该图实际有以下路径:

V1->V2->V5->V7->V9;
V1->V3->V5->V7->V9;
V1->V2->V5->V8->V9;
V1->V3->V5->V8->V9;
V1->V4->V6->V8->V9;

一共是5条路径,这5条路径上面的权值和最大者就是关键路径。

很明显,把上述5条路径的V1合并成一个结点,则可以看这个结果实际是一个生成树,这个生成树上的结点或许是重复的,但要全部走完,则结果肯定是这样的一棵树,这样的树我们这里成为全路径生成树,或许N多教材没这个称谓,但要编程求解该问题则必然是要先解出该树来、然后累计求和每个子树上的权值和。

C#的程序上很容易做到这个树,这个解就是:

在这里插入图片描述

这样的树,实际是一种特殊的深度优先遍历生成的结果。

回顾我们在普通的图上做的深度优先遍历,由于一般意义上的图中存在回路,所以我们需要一个Visited[]这样的数组、标记已经走过的顶点,从而制止了在一个回路上无限循环,但我们分析AOE图则不难发现:我们不需要标记已经走过的顶点,深度优先遍历也可以顺利从源点到汇点走完。

手工完成这样的遍历不是问题,所以我们可以编写出以下的程序来遍历:

void AOETrav (struct Graph *G,int n)
{int i;if(G==NULL) return;printf("%d\t%s\n",n,G->pV[n]);for(i=0;i<G->num;i++)if(G->pA[n][i]!=0)AOETrav(G,i);
}

对照我们前面的深度优先遍历函数:

void DFS(struct Graph *G,int n)
{int i;if(G==NULL) return;if(n<0||n>G->num) return;G->Visited[n]=1;printf("%s ",G->pV[n]); for(i=0;i<G->num;i++)if(G->pA[n][i]!=0&&G->Visited[i]!=1) 
DFS(G,i);
}

执行AOE1.c程序,则结果是:

V1、 V2、V5、V7、 V9、V8、V9、V3、V5、V7、V9、 V8、V9、V4、V6、V8、V9  

分析表1的程序以及结果不难发现:

<1> 如AOETrav( )函数入口参数n是生成树父结点的话、那么在第8行进入下一个顶点时所找到的第i个顶点、则就是第n个结点的孩子;

<2> 如果设到第n个结点的权值累计合是w,则该函数就是这样的入口参数:

void AOETrav (struct Graph *G,int n,int w)

有这样的函数后,则在表1的第9行就是:

AOETrav(G,i, w+G->pA[n][i]);

也就是说:到第n个顶点的权值如果是w的话,则到第n个后的第i个顶点,其权值合计是:

w+A[n][i];

然后,我们设计一个双亲表示法的表格,按:
在这里插入图片描述

void AOETrav (struct Graph *G,int n,int w)
{int i,nw;if(G==NULL) return;for(i=0;i<G->num;i++)if(G->pA[n][i]!=0){nw=w+G->pA[n][i]; printf("%d\t%d\t%s\t%d\n",i,n,G->pV[i],nw);AOETrav(G,i,nw);}
}

修改main()函数,使其从第0个顶点开始,就是:

main()
{int i,j;struct Stack *S;struct Graph *G;G=GraphCreat("p200G736.txt");printf("顶点名称:\n");for(i=0;i<G->num;i++)printf("%s\t",G->pV[i]);printf("\n邻接矩阵:\n");for(i=0;i<G->num;i++) {for(j=0;j<G->num;j++)printf("%d\t",G->pA[i][j]);printf("\n");}printf("\n");printf("ID\tPID\tV\tW\n");printf("%d\t%d\t%s\t%d\n",0,-1,G->pV[0],0);AOETrav(G,0,0);
}

运行这个程序,会有以下结果:

在这里插入图片描述
至此,AOE的问题基本解决,查看表6,其最大权值是18,见上表第4行、第6行,如是第4行,则是V9,回溯PID=6到第3行V7、从V7取PID=4回到第2行V5、再从PID=1回到V2、从V2取PID=0回到V1,全路程就是:

V1、V2、V5、V7、V9,全路程权值合计是18

同理在第6行也有一条路径:

V1、V3、V5、V8、V9,全路程权值和也是18,这也是一条关键路径。

表6需要注意的是:由于这个树上、一个结点可能出现在好几个子树上,所以父结点编号要寻找上面最近的结点编号。

AOE完整求解程序

上述解法、对小的AOE图是可行的,但在大的图上,很明显对表6也需要进行编程处理,所以一个完整的AOE处理程序,还需要设计一个顺序表、保存表6的结果,然后通过顺序表求解出完整的计算结果。这个工作就留给同学们自己解决。

AOE2.c是通过一种简单的方式、把各个路径上的权值累计合计和路径显示出来的程序,请同学们自己分析。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/285146.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言试题160之某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下: 每位数字都加上 5,然后用和除以 10 的余数代替该数字,再将第一位和第四位交换,第二位和第三位

📃个人主页:个人主页 🔥系列专栏:C语言试题200例 💬推荐一款模拟面试、刷题神器👉 点击跳转进入网站 ✅作者简介:大家好,我是码莎拉蒂,CSDN博客专家(全站排名Top 50),阿里云博客专家、51CTO博客专家、华为云享专家 1、题目 题目:某个公司采用公用电话传递数…

C# 关于状态机的实现(案例版)

大部分的状态机都是有限状态机&#xff0c;某些业务环境&#xff0c;或者其他环境中&#xff0c;如果有状态机其实还是很方便的。比如&#xff0c;我是用在了单个客户的Socket通信上&#xff0c;未连接状态&#xff0c;我就等连接。已连接状态&#xff0c;就等待下一步指令状态…

[转]Android 项目的代码混淆,Android proguard 使用说明

简介 Java代码是非常容易反编译的。为了很好的保护Java源代码&#xff0c;我们往往会对编译好的class文件进行混淆处理。 ProGuard是一个混淆代码的开源项目。它的主要作用就是混淆&#xff0c;当然它还能对字节码进行缩减体积、优化等&#xff0c;但那些对于我们来说都算是次要…

数据结构与算法:终于可以用三种语言(C,C#,JavaScript)把图的广度优先遍历讲清楚了(推荐收藏)

文章目录邻接矩阵存储图的广度优先遍历过程分析C语言实现队列编程程序中加入图的处理函数结果的再次分析C#语言实现图的广度优先遍历、并显示广度优先遍历生成树JavaScript语言实现图的广度优先遍历、并显示广度优先遍历生成树邻接矩阵存储图的广度优先遍历过程分析 对图1这样…

C语言试题161之求100000以内的自守数

📃个人主页:个人主页 🔥系列专栏:C语言试题200例 💬推荐一款刷算法、笔试、面经、拿大公司offer神器👉 点击跳转进入网站 ✅作者简介:大家好,我是码莎拉蒂,CSDN博客专家(全站排名Top 50),阿里云博客专家、51CTO博客专家、华为云享专家 1、题目 题目:自守数是…

改造.NET遗留应用

浅议.NET遗留应用改造TLDR&#xff1a;本文介绍了遗留应用改造中的一些常见问题&#xff0c;并对改造所能开展的目标、原则、策略进行了概述。一、背景概述1、概述或许仅“遗留应用”这个标题就比较吸睛&#xff0c;因为我听过太多人吐槽了。Robert Martin在《修改代码的艺术》…

GitHub的DGit改进了平台的可靠性、性能以及可用性

GitHub最近悄悄地发布了DGit&#xff0c;全称为“分布式Git”。这是一种基于Git创建的分布式存储系统&#xff0c;其目标是改进使用GitHub时的可靠性、可用性以及性能。\\DGit是一个应用层面的协议&#xff0c;它利用了Git分布式的特性&#xff0c;将每个仓库在三台不同的、独立…

用静态NAT实现外网PC访问内网服务器

在我们的生产环境中常常处于安全考虑将服务器置于内网环境中&#xff0c;但同时得向外网提供各种服务功能&#xff0c;此时就需要用到NAT技术。下面是我用思科的仿真软件搭建的一个实验环境&#xff0c;实现外网PC访问内网服务器。先说明一下实验环境&#xff1a;路由器R0左边为…

[转]分布式事务之TCC服务设计和实现注意事项

1、TCC简介 TCC是一种比较成熟的分布式事务解决方案&#xff0c;可用于解决跨库操作的数据一致性问题&#xff1b; TCC是服务化的两阶段编程模型&#xff0c;其Try、Confirm、Cancel 3个方法均由业务编码实现&#xff1b; 其中Try操作作为一阶段&#xff0c;负责资源的检查和…

量化投资策略的评估标准及其计算公式

收益率指标&#xff1a;分为策略的总收益率和策略的年化收益率 策略的总收益率&#xff1a; 策略的总收益率是评价一个策略盈利能力的最基本的指标&#xff0c;其计算方法为&#xff1a; 公式中Vt表示策略最终的股票和现金的总价值&#xff0c;V0表示策略最初的股票和现金的总…

【ArcGIS微课1000例】0005:空间连接(Spatial Join)

问题描述 现在要根据范围,怎样批量统计各个范围内的湖泊的总面积、各个省份内的铁路或河流总长度、各个地区的人口综合等。 空间连接 根据空间关系将一个要素类的属性连接到另一个要素类的属性。目标要素和来自连接要素的被连接属性写入到输出要素类。 用法 空间连接是指根…

【微服务专题之】.Net6中集成消息队列-RabbitMQ中直接路由模式

微信公众号&#xff1a;趣编程ACE关注可了解更多的.NET日常实战开发技巧&#xff0c;如需源码 请公众号后台留言 源码;[如果觉得本公众号对您有帮助&#xff0c;欢迎关注]前文回顾【微服务专题之】.Net6下集成消息队列上-RabbitMQ【微服务专题之】.Net6下集成消息队列2-RabbitM…

C语言试题162之圆周率π

📃个人主页:个人主页 🔥系列专栏:C语言试题200例 💬推荐一款刷算法、笔试、面经、拿大公司offer神器👉 点击跳转进入网站 ✅作者简介:大家好,我是码莎拉蒂,CSDN博客专家(全站排名Top 50),阿里云博客专家、51CTO博客专家、华为云享专家 1、题目 题目:圆周率π…

第14、15教学周作业

要求一 还差一些没做完。 要求二 USTH_C程序设计&#xff08;基础&#xff09;14周第一次PTA作业 7-3 将数组中的数逆序存放 1.实验代码 #include<stdio.h>int main() {int i,n,t;scanf("%d",&n);int a[n];for(i0;i<n;i){scanf("%d",&t)…

代理(Proxy)

2019独角兽企业重金招聘Python工程师标准>>> 一、代理的概念 动态代理技术是整个java技术中最重要的一个技术&#xff0c;它是学习java框架的基础&#xff0c;不会动态代理技术&#xff0c;那么在学习Spring这些框架时是学不明白的。 动态代理技术就是用来产生一个对…

【ArcGIS微课1000例】0006:创建随机点(Create Random Points)

问题描述 在一个给定的范围内,根据随机位置,生成指定数量的随机点。生成的随机点通常用来提取每个点对应的NDVI,高程,气温等值。 ArcGIS创建随机点 创建指定数量的随机点要素。可以在范围窗口中、面要素内、点要素上或线要素沿线生成随机点。 工具介绍:

[转]《吐血整理》系列-顶级程序员工具集

你知道的越多&#xff0c;你不知道的越多 点赞再看&#xff0c;养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式&#xff0c;欢迎Star和指教 前言 这期是被人才群交流里&#xff0c;还有很多之前网友评论强行顶出来的一期&#x…

跟我做⼀个高德地图的 iOS / Android MAUI 控件(前言)

Microsoft Build 2022 ⼤会上正式发布了 .NET MAUI , 对于 .NET 开发者可以⽤ C# 完成跨平台的前端应⽤开发。对⽐起 MAUI 的前身 Xamarin , MAUI 除了可以⽤传统的原⽣开发模式外&#xff0c;还⽀持了 Blazor 的混合式开发。这也让更多⽅向的开发⼈员能进⼊到跨平台的应⽤开发…

Valid Number

Valid Number 题解 题目描述 即判断某个字符串是否合法的数字表达式。如&#xff1a; 2e10&#xff0c;合法。 75.0.&#xff0c;非法。 0e&#xff0c;非法。 0.1 &#xff0c;合法。题解 基于规则与状态判断。可利用二维数组模拟状态转移图&#xff0c;又或是利用变量记录状…

java.util.ListIterator

列表迭代器并不持有当前元素的引用&#xff0c;其持有的游标是位于列表连个元素之间。可以通过调用next()或者previous()返回列表中的元素。一个拥有n个元素的列表拥有n1个游标位置&#xff0c;示意图如下&#xff1a; 注意&#xff1a;remove和 set(Object)方法并不是以迭代器…