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

相关文章

python使用fastapi实现多语言国际化的操作指南

《python使用fastapi实现多语言国际化的操作指南》本文介绍了使用Python和FastAPI实现多语言国际化的操作指南,包括多语言架构技术栈、翻译管理、前端本地化、语言切换机制以及常见陷阱和... 目录多语言国际化实现指南项目多语言架构技术栈目录结构翻译工作流1. 翻译数据存储2. 翻译生成脚本

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

C语言中自动与强制转换全解析

《C语言中自动与强制转换全解析》在编写C程序时,类型转换是确保数据正确性和一致性的关键环节,无论是隐式转换还是显式转换,都各有特点和应用场景,本文将详细探讨C语言中的类型转换机制,帮助您更好地理解并在... 目录类型转换的重要性自动类型转换(隐式转换)强制类型转换(显式转换)常见错误与注意事项总结与建议类型

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

Go语言利用泛型封装常见的Map操作

《Go语言利用泛型封装常见的Map操作》Go语言在1.18版本中引入了泛型,这是Go语言发展的一个重要里程碑,它极大地增强了语言的表达能力和灵活性,本文将通过泛型实现封装常见的Map操作,感... 目录什么是泛型泛型解决了什么问题Go泛型基于泛型的常见Map操作代码合集总结什么是泛型泛型是一种编程范式,允

Android kotlin语言实现删除文件的解决方案

《Androidkotlin语言实现删除文件的解决方案》:本文主要介绍Androidkotlin语言实现删除文件的解决方案,在项目开发过程中,尤其是需要跨平台协作的项目,那么删除用户指定的文件的... 目录一、前言二、适用环境三、模板内容1.权限申请2.Activity中的模板一、前言在项目开发过程中,尤

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.