四、数学建模之图与网络模型

2023-09-14 16:21:41

1.定义
2.例题及软件代码求解

一、定义

1.图和网络是相关概念

(1)(Graph):图是数学和计算机科学中的一个抽象概念,它由一组节点(顶点)和连接这些节点的边组成。图可以是有向的(有方向的,边有箭头表示方向)或无向的(没有方向的,边没有箭头表示方向)。图用于表示各种关系,如社交网络、电路、地图、组织结构等。

(2)网络(Network):网络是一个更广泛的概念,可以包括各种不同类型的连接元素,不仅仅是图中的节点和边。网络可以包括节点、边、连接线、路由器、服务器、通信协议等多种组成部分。网络的概念在各个领域都有应用,包括计算机网络、社交网络、电力网络、交通网络等。

2.图论的概念

(1)图:图是由一组节点(顶点)和连接这些节点的边组成的数学结构。图可以分为有向图和无向图,根据边是否有方向。

(2)顶点:顶点是图中的节点,它们可以代表不同的实体或对象。

(3)边:边是连接两个顶点的线段,它可以表示顶点之间的关系或连接。

(4)有向图:有向图是一种图,其中边有方向,从一个顶点指向另一个顶点。

(5)无向图:无向图是一种图,其中边没有方向,只表示两个顶点之间的连接。

(6)最小生成树问题:在一个连通图中,寻找一个包含所有顶点的子图,使得边的权重之和最小,被称为最小生成树问题。其中,Prim算法和Kruskal算法是解决这个问题的常用方法。

(7)路径:路径是图中一系列相邻的顶点,它们通过边相连。

(8)环:环是一条路径,起始点和结束点相同,形成一个闭合的循环。

(9)连通图:如果在无向图中,任意两个顶点之间都存在路径,那么这个图是连通的。对于有向图,可以有强连通图的概念。

(10)度数:一个顶点的度数是与它相邻的边的数量。在有向图中,分为入度和出度。

(11)图的表示:图可以用邻接矩阵、邻接表等不同方式来表示,这取决于需要进行的操作和问题类型。

(12)最短路径问题:寻找两个顶点之间最短路径的问题是图论中的一个经典问题,例如Dijkstra算法和Bellman-Ford算法。

3.稀疏矩阵表示法

一种用于有效存储处理稀疏矩阵(大部分元素为零)的方法。在很多实际应用中,矩阵中的许多元素都是零,因此使用传统的密集矩阵表示法会浪费大量的存储空间和计算资源。稀疏矩阵表示法可以显著减少这种浪费。

常见的稀疏矩阵表示法

(1)压缩稀疏行表示法:在CSR表示法中,矩阵被分为三个数组:值数组(非零元素的值)、列索引数组(每个值对应的列索引)、行偏移数组(每行的起始位置在值数组中的索引)。这种表示方法适用于稀疏矩阵中的非零元素分散地分布在各行中的情况。

(2)压缩稀疏列表示法:与CSR类似,CSC也使用值数组、行索引数组和列偏移数组,但是列偏移数组表示每列的起始位置。CSC适用于稀疏矩阵中的非零元素分散地分布在各列中的情况。

(3)三元组表示法:在这种表示法中,矩阵的每个非零元素都由一个三元组 (行号、列号、元素值) 来表示。适用于初始构建稀疏矩阵或者非常稀疏的情况,但不太适用于高效的矩阵操作。

(4)对角线存储法:当稀疏矩阵具有对角线稀疏性(非零元素主要分布在对角线上)时,可以使用对角线存储法,只存储对角线及其附近的元素。

(5)块压缩表示法:对于某些特定应用,可以将矩阵分成块,并对每个块使用一种稀疏矩阵表示法。这对于一些科学计算和图像处理任务中的大型稀疏矩阵很有用。

二、例题(matlab或lingo求解)

1.矩阵表示有向图
在这里插入图片描述
在这里插入图片描述
2.例 某公司在六个城市 中有分公司,从 到 的直接航程票价记在下述矩阵的 位置上。( 表示无直接航路),请帮助该公司设计一张城市 到其它城市间的票价最便宜的路线图。
在这里插入图片描述

clc,clear
a=zeros(6);
a(1,2)=50;a(1,4)=40;a(1,5)=25;a(1,6)=10;
a(2,3)=15;a(2,4)=20;a(2,6)=25;
a(3,4)=10;a(3,5)=20;
a(4,5)=10;a(4,6)=25;
a(5,6)=55;
a=a+a';
a(find(a==0))=inf;
pb(1:length(a))=0;pb(1)=1;index1=1;index2=ones(1,length(a));
d(1:length(a))=inf;d(1)=0;temp=1;
while sum(pb)<length(a)
 tb=find(pb==0);
 d(tb)=min(d(tb),d(temp)+a(temp,tb));
 tmpb=find(d(tb)==min(d(tb)));
 temp=tb(tmpb(1));
 pb(temp)=1;
 index1=[index1,temp];
 temp2=find(d(index1)==d(temp)-a(temp,index1));
 index2(temp)=index1(temp2(1));
end
d, index1, index2

3.例 在图 3 中,用点表示城市,现有 A, B1, B2 ,C1,C2 ,C3 , D 共 7 个城市。点与
点之间的连线表示城市间有道路相连。连线旁的数字表示道路的长度。现计划从城市 A到城市 D 铺设一条天然气管道,请设计出最小价格管道铺设方案。
在这里插入图片描述
编写 LINGO 程序如下:


model: 
sets: 
cities/A,B1,B2,C1,C2,C3,D/; 
roads(cities,cities)/A B1,A B2,B1 C1,B1 C2,B1 C3,B2 C1, 
B2 C2,B2 C3,C1 D,C2 D,C3 D/:w,x; 
endsets 
data: 
w=2 4 3 3 1 2 3 1 1 3 4; 
enddata 
n=@size(cities); !城市的个数; 
min=@sum(roads:w*x); 
@for(cities(i)|i #ne#1 #and# i #ne#n: 
@sum(roads(i,j):x(i,j))=@sum(roads(j,i):x(j,i))); 
@sum(roads(i,j)|i #eq#1:x(i,j))=1; 
@sum(roads(i,j)|j #eq#n:x(i,j))=1; 
end 
  1. 例无向图的最短路问题)求图 4 中 1 v 到 11 v 的最短路。

在这里插入图片描述
编写 LINGO 程序如下

:
model: 
sets: 
cities/1..11/; 
roads(cities,cities):w,x; 
endsets 
data: 
w=0; 
enddata 
calc: 
w(1,2)=2;w(1,3)=8;w(1,4)=1; 
w(2,3)=6;w(2,5)=1;
w(3,4)=7;w(3,5)=5;w(3,6)=1;w(3,7)=2; 
w(4,7)=9; 
w(5,6)=3;w(5,8)=2;w(5,9)=9; 
w(6,7)=4;w(6,9)=6; 
w(7,9)=3;w(7,10)=1; 
w(8,9)=7;w(8,11)=9; 
w(9,10)=1;w(9,11)=2;w(10,11)=4; 
@for(roads(i,j):w(i,j)=w(i,j)+w(j,i)); 
@for(roads(i,j):w(i,j)=@if(w(i,j) #eq# 0, 1000,w(i,j))); 
endcalc 
n=@size(cities); !城市的个数; 
min=@sum(roads:w*x); 
@for(cities(i)|i #ne#1 #and# i #ne# 
n:@sum(cities(j):x(i,j))=@sum(cities(j):x(j,i))); 
@sum(cities(j):x(1,j))=1; 
@sum(cities(j):x(j,1))=0; !不能回到顶点1; 
@sum(cities(j):x(j,n))=1; 
@for(roads:@bin(x)); 
end
更多推荐

二叉搜索树经典笔试题【力扣、牛客】

文章目录1.根据二叉树创建字符串2.二叉树的层序遍历3.二叉树的层序遍历Ⅱ4.二叉树的最近公共祖先1.法一:定位p、q在左还是右分类讨论2.法二:利用stack求出p、q路径求相交值5.二叉搜索树与双向链表1.法一:递归:递归过程修正指针指向2.数组:将二叉搜索树进行中序遍历可以得到由小到大的顺序排列6.前序中序遍历序

Spark_Spark内存模型管理

工作中经常用到Spark内存调参,之前还没对这块记录,这次记录一下。环境参数spark内存模型中会涉及到多个配置,这些配置由一些环境参数及其配置值有关,为防止后面理解混乱,现在这里列举出来,如果忘记了,可以返回来看看:spark.executor.memory:JVMOn-Heap内存(堆内内存),在使用sparksu

云服务器部署k8s集群

在两台不同厂商的云服务器上部署k8s集群,遇到一些问题。在此进行下总结。首先要网络能够互通,我是通过添加虚拟网卡的方式lsmod|grepip_vs#检查是否有开启#临时开启ip_vsforiin$(ls/lib/modules/$(uname-r)/kernel/net/netfilter/ipvs|grep-o"^

【Spark】PySpark DataFrame

1SparkSession执行环境入口2构建DataFrame2.1由rdd构建(StructType、StructField)2.2由pandas.DataFrame构建2.3由外部数据构建2.3.1text数据源2.3.2json数据源2.3.3csv数据源3DataFrame操作3.1SQL风格3.2DSL风格3

WebGL HUD(平视显示器)

目录HUD(平视显示器)如何实现HUD示例程序(HUD.html)示例程序(HUD.js)代码详解在网页文字上方显示三维物体代码详解HUD(平视显示器)平视显示器(headupdisplay)简称HUD,最早用于飞机驾驶。平视显示器将一些重要信息投射到飞机驾驶舱前方的一块玻璃上,飞行员能够将外界的影像和这些重要信息融合

使用vue-cli搭建SPA项目

目录一、SPA项目构建及目录讲解1.1SPA定义1.2SPA优点1.3VueCLI定义1.4VueCLI功能解析1.5安装vue-cli1.6创建SPA项目1.7项目结构说明1.8项目结构说明1.8.1build文件夹1.8.2config文件夹1.8.3node_modules文件夹1.8.4src文件夹1.8.5s

ctfshow web入门(2)

web11打开这个网站,到网站诊断分析模块搜索域名web12提示有时候网站上的公开信息,就是管理员常用密码打开,就是个购物网站因为昨天刚做robots.txt我就搜了一下真的有,提示admin这个页面访问一下,username肯定是admin,但是密码。有点晕。但是看到提示我就又去看了看原来的页面,有没有可疑的密码在末

MQTT服务器搭建

本次搭建的MQTT服务器是emqx提供的服务器1、下载https://www.emqx.com/en/downloads/broker从官网下载5.2.0版本emqx-5.2.0-windows-amd64.zip下载完成直接安装2、配置,修改端口号mqtt默认端口号常规的用法,我们一般使用和开放这两个端口:1883,

php生成随机验证码图片

1,CaptchaPicture.php用于生成画布,然后在画布上生成四位随机验证码<?phpsession_start();header("Content-type:image/png");//创建图像的格式$image_width=76;//设置图像的宽度$image_height=40;//设置图像的高度$len

线性代数与编程语言结合 基础

什么是线性代数线性代数是数学的一个分支,研究向量空间和线性变换的理论与方法。它涉及了向量、矩阵、线性方程组、线性映射等概念与运算规则。线性代数在科学和工程领域中被广泛应用,如物理学、计算机图形学、统计学、电子工程等。它提供了一种强大的工具和语言来描述和解决线性问题,比如矩阵求逆、解线性方程组、特征值和特征向量等。通过线

抖音矩阵系统源码:开发搭建

一、抖音矩阵系统源码开发概述抖音seo矩阵系统源码开发技术要求十分严格。首先,需要熟练掌握Python、Java等编程语言,具有扎实的算法基础。在此基础上,还需要具备深度学习、神经网络等相关技能,能够实现精准推荐和内容分析等功能。其次,抖音seo矩阵系统开发还需要专业的云计算技术支持,比如分布式计算、负载均衡等,以确保

热文推荐