C语言利用计算机找系统的最小通路集的算法

2023-10-12 12:15

本文主要是介绍C语言利用计算机找系统的最小通路集的算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

背景:

有人求助到博主希望分析一下他们老师给出的题目,博主思路分析和解题过程如下

题目要求:

联络矩阵法,当 n 较小时可以用手算,当然也可以用计算机计算。但当 n 很大时,需要计
算机的容量很大才行。为此要探求有效的计算机算法,这里介绍的一种是由输入节点到输出
节点找最小通路集的计算机算法。
设系统是由 n 个节点组成的有向网络系统,并设节点对间无并行弧,整个计算机算法的
思路为:
1 输入节点 I 作为起始节点;
2 由起始节点出发,选下一步可到达的节点 j;
3 判断节点 j 是否走过,若已走过则后退一步,以上一个节点作为起始节点,转②;
4 判断是否已达到输出节点 L,若未到,则把 j 作为起始点,转②;
5 判断是否已找到了所有的路,若否,则后退两步,把上面两个节点作为起始节点,
转②;
6 结束
由以上可见,计算机算法的关键是要进行几个判断:
1 判断节点是否与前面走过的节点重复;
2 判断是否已找到了一条路;
3 判断是否已找到了所有的路。
为了实现计算机算法,还需要定义如下:
1 可以描述从一个节点 j 可以进一步到达所有节点的矩阵,该矩阵称为路线矩阵,表
示为
[R(j,C(j))] R  (1)
式中 j = 1,2,…,n
C(j)=1,
j
E 其中
j
E 表示 R 的第 j 行可到达的节点数。
路线矩阵 R 的第 j 行记录了节点 j 可以进一步到达的所有节点标号。R 不一定是长方阵,
对于不同的行,列数不一定相等,可用 0 补齐。

过程思路【重要】:

大家不要被概念绕混了!!

将问题简单化,我们针对题目中题目中的有向图2进行分析!

它其实就是一个求解起点4到起点6的一共有多少条路径的问题,给大家上一张图,大家应该就明白了!

可以看到H->S,H->B->M,H->B->C->D等一共7条线段,就是有向网络图2的,从起点4到终点6的所有最小通路集长的结果。

下面给出程序运行效果示例。

程序运行效果[用户可动态输入数据]:

程序可实现用户动态构造一个有向图,用户输入起点和终点,程序最终输出从该起点到终点的所有路径。

主要代码:

//联系请加V:zew1040994588int main() {DirectedGraph graph;int numVertices, numEdges;char vertexName[20];char startVertexName[20], endVertexName[20], edgeName[20];printf("请输入图中顶点的数量:");scanf("%d", &numVertices);initDirectedGraph(&graph, numVertices);printf("请输入顶点名称:\n");for (int i = 0; i < numVertices; i++) {scanf("%s", graph.vertexNames[i]);}printf("请输入图中边的数量:");scanf("%d", &numEdges);printf("请输入边(格式:起点 终点 边名称):\n");for (int i = 0; i < numEdges; i++) {scanf("%s %s %s", startVertexName, endVertexName, edgeName);addDirectedEdge(&graph, startVertexName, endVertexName, edgeName);}printf("请输入起点顶点名称:");scanf("%s", startVertexName);printf("请输入终点顶点名称:");scanf("%s", endVertexName);findPath(&graph, startVertexName, endVertexName);return 0;
}

这篇关于C语言利用计算机找系统的最小通路集的算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

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

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

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

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 初始化

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

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. 建立数据库连接二、定义模型结构体三、自动迁

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

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

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

Mac系统下卸载JAVA和JDK的步骤

《Mac系统下卸载JAVA和JDK的步骤》JDK是Java语言的软件开发工具包,它提供了开发和运行Java应用程序所需的工具、库和资源,:本文主要介绍Mac系统下卸载JAVA和JDK的相关资料,需... 目录1. 卸载系统自带的 Java 版本检查当前 Java 版本通过命令卸载系统 Java2. 卸载自定