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

相关文章

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

Linux查询服务器系统版本号的多种方法

《Linux查询服务器系统版本号的多种方法》在Linux系统管理和维护工作中,了解当前操作系统的版本信息是最基础也是最重要的操作之一,系统版本不仅关系到软件兼容性、安全更新策略,还直接影响到故障排查和... 目录一、引言:系统版本查询的重要性二、基础命令解析:cat /etc/Centos-release详

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.