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

相关文章

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

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

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

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

Ubuntu系统怎么安装Warp? 新一代AI 终端神器安装使用方法

《Ubuntu系统怎么安装Warp?新一代AI终端神器安装使用方法》Warp是一款使用Rust开发的现代化AI终端工具,该怎么再Ubuntu系统中安装使用呢?下面我们就来看看详细教程... Warp Terminal 是一款使用 Rust 开发的现代化「AI 终端」工具。最初它只支持 MACOS,但在 20

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用