[matlab] 22.matlab图论实例 最短路问题与最小生成树 (转载)
最短路问题之 Floyd
某公司在六个城市 c1c1,c2c2,….,c6c6 中有分公司,从 cici 到 cjcj 的直接航程票价记在下述矩阵的 (ii,jj) 位置上。 (∞∞表示无直接航路),请帮助该公司设计一张城市 c1c1 到其它城市间的票价便宜的路线图。

变量解释:
- n 是公司个数
- a 存储航路票价,最后结束循环存储的是最便宜票价
- path 存储每对顶点之间最短路径上所经过的定点的序号,也就是”中转站”序号
clear;clc;
n = 6;
a = [0 50 inf 40 25 10;
0 0 15 20 inf 25;
0 0 0 10 20 inf;
0 0 0 0 10 25;
0 0 0 0 0 55;
0 0 0 0 0 0]; % 由于 a 是无向图,航路票价沿着正对角线对称,可以只写出右上角
a = a + a'; % 由于票价沿正对角线对称,即完整的 a 为 a + a 的转置
path = zeros(6); % 定义 path 为 6 x 6 的矩阵
for k = 1:n
for i = 1:n
for j = 1:n
if a(i,j) > a(i,k) + a(k,j)
% 如果从 i 城市到 j 城市的票价大于从 i 城市到 k,再从 k 到 j 城,那么 i 到 j 城肯定不是最短路径
a(i,j) = a(i,k) + a(k,j); % 更新 i 到 j 的最少票价
path(i,j) = k; % 同时记录下 i 到 j 的"中转站"
% 注意下一次更新会覆盖上一次 path(i,j) 存储的,所以其实 path(i,j)中存储的 只是最后一个 "中转站"
end
end
end
end
a,path
Floyd 算法

最短路问题之 dijkstra 算法
变量解释:
- n 是公司个数
- m 存储票价
- pb 存放标号信息,当 pb(ii) = 1,当前第 ii 节点已标号,否则为 0 未标号
- d 表示最短通路的值
- path 存储每对顶点之间最短路径上所经过的定点的序号
- tb 表示当前未标记的点的矩阵
- fb 表示当前已标记的点的矩阵
- min 求最小值之前的预设值
- lastpoint 暂存当前选定的一个已标记点
- newpoint 暂存当前选定的一个未标记点
- plus 即已知点到未知点距离
clear;clc;
n = 6;
m = [0 50 inf 40 25 10;
0 0 15 20 inf 25;
0 0 0 10 20 inf;
0 0 0 0 10 25;
0 0 0 0 0 55;
0 0 0 0 0 0];
m = m + m';
pb(1:length(m))= 0; % 将所有未标记点置 0
pb(1) = 1; % 选择第 1 个点标记
d(1:length(m))=0; % 将全部最短距离置 0
path(1:length(m))=0; % 将全部"中转站"置 0
while sum(pb) < 6 % 当状态不全为 1(即未标记全部点时)
tb = find(pb==0); % 找到未标记的点的矩阵
fb = find(pb==1); % 找到已标记的点的矩阵
min = 1000000;
lastpoint =1;
newpoint =1;
% 从每一个已标记点,到每一个未标记点
for i=1:length(fb)
for j=1:length(tb)
plus = d(fb(i)) + m(fb(i),tb(j)); % 计算点之间的距离
if min > plus
min = plus; % 更新最小值
lastpoint = fb(i); % 记录当前最小值下已标记点
newpoint = tb(j); % 记录当前最小值下未标记点
end
end
end
d(newpoint) = min; % 更新最终的最小值
pb(newpoint) = 1; % 更新当前未标记点状态(未标记——》标记)
path(newpoint) = lastpoint; % 更新当前点上一个点
end
d,path
dijkstra 算法

最小生成树问题之prim

变量解释:
- n 顶点个数
- a 存储图
- result 第一、二、三行分别表示生成树边的起点、终点、权集合
- p 存放图的最小生成树中的顶点
- tb 存放当前未选择的顶点
- temp 存放当前最小生成树连通的所有边
- d 存放最小的边值
- jb 存放最小的边值中已经选作最小生成树的点的矩阵(也许不止一个)
- kb 存放最小的边值中未选作最小生成树的点的矩阵(也许不止一个)
- j 确定已经选作最小生成树的点的矩阵中的第一个点
- k 确定未被选作最小生成树的点的矩阵中的第一个点
clear;
clc;
n = 7;
a = [0 50 60 inf inf inf inf;
0 0 inf 65 40 inf inf;
0 0 0 52 inf inf 45;
0 0 0 0 50 30 42;
0 0 0 0 0 70 inf;
0 0 0 0 0 0 inf;
0 0 0 0 0 0 0];% 由于 a 是无向图,航路票价沿着正对角线对称,可以只写出右上角
a = a + a'; % 由于票价沿正对角线对称,即完整的 a 为 a + a 的转置
result =[]; % 定义出 result
p =1; % 当前只有第 1 个点为最小生成树的节点
tb =2:n; % 当前未作为最小生成树的节点
while length(result) ~= n - 1 % 当生成树的边为 节点数-1 时,即最小生成树生成(n个点 n-1 条边)
temp = a(p,tb); % 存放当前最小生成树连通的所有边,用来求最短边
temp = temp(:); % 将 temp 转化成 1 列,让求出的最短距离只有一个值
d = min(temp); % 求出最短距离
[jb,kb] = find(a(p,tb)==d); % 根据最短距离,找出哪些点符合最短距离的情况
j = p(jb(1)); % 从当前最小生成树中的点中
k = tb(kb(1)); % 和当前未进入最小生成树的点中挑出第一个点
result = [result,[j;k;d]]; % 表示生成树边的起点、终点、权集合
p = [p,k]; % 刚刚选的点进入最小生成树
tb(find(tb==k)) =[]; % 将进入最小生成树的点剔除掉
end
result
prim 算法

最小生成树问题之kruskal (待补充)
[matlab] 22.matlab图论实例 最短路问题与最小生成树 (转载)的更多相关文章
- MATLAB神经网络原理与实例精解视频教程
教程内容:<MATLAB神经网络原理与实例精解>随书附带源程序.rar9.随机神经网络.rar8.反馈神经网络.rar7.自组织竞争神经网络.rar6.径向基函数网络.rar5.BP神经网 ...
- C语言与MATLAB接口 编程与实例 李传军编着
罗列一下以前自己学习C语言与MATLAB混编的笔记,顺便复习一遍. <C语言与MATLAB接口 编程与实例 李传军编着>(未看完,目前看到P106) 目录P4-8 ************ ...
- matlab load函数用法 实例
一 语法: load(filename) load(filename,variables) load(filename,'-ascii') load(filename,'-mat') load(fil ...
- matlab绘制实用日历实例代码
function TheStudy;%函数名 close all;%关闭所有床头 DD={'Sun','Mon','Tue','Wed','Thu','Fri','Sat'};%日历表头文字 figu ...
- matlab文件读写处理实例(三)——读取文件特定行
(1) 读取文件特定行 CODE: ; ; if nline==line fprintf(fidout,'%s\n',tline); data ...
- matlab文件读写处理实例(二)——textread批量读取文件
问题:对文件夹下所有文件进行批量读取,跳过文件头部分,读取每个文件数据部分的7,8,9列,保存到变量并且输出到文件. 数据: 文件夹11m\
- matlab文件读写处理实例(一)——不规则文件读取
数据: A) Title: Income Data B) Relevant Information: Marketing Database. Source: Impact Resources, Inc ...
- Matlab 编程简介与实例
函数作图 二维平面曲线作图函数 plot(x, y, 's') x, y是长度相同的向量,s表示线型和颜色 如果作多条曲线在同一图上,则用函数: plot(x1, y1, 's1', x2, y2, ...
- [Matlab]三维曲面绘制实例
[x,y] = meshgrid(-8:0.5:8); z = sin(sqrt(x.^2+y.^2))./sqrt(x.^2+y.^2+eps); subplot(2,2,1); mesh(x,y, ...
随机推荐
- 4.7 explain 之 Extra
一.说明 包含不合适在其他列中显示,但十分重要的信息. 二.分类 a. Using filesort : 说明mysql 会对数据使用一个外部的索引排序,而不是按照表内的索引顺序排序进行读取的.mys ...
- python基础学习(五)while循环语句
while循环基本使用 循环的作用就是让指定的代码重复的执行 while循环最常用的应用场景就是让执行的代码按照指定的次数重复执行 流程图 基本语法 初始条件设置 —— 通常是重复执行的 计数器 wh ...
- Laravel 系列入门教程(三)【最适合中国人的 Laravel 教程】
在本篇文章中,我们将尝试构建一个带后台的简单博客系统.我们将会使用到 路由.MVC.Eloquent ORM 和 blade 视图系统. 简单博客系统规划 我们在教程一中已经新建了一个继承自 Eloq ...
- 下载使用前端开发工具sublime,并汉化
官网:www.sublimetext.com 汉化流程:安装package control 1.打开“https://packagecontrol.io/installation”,先下载“packa ...
- loj#6031. 「雅礼集训 2017 Day1」字符串(SAM 广义SAM 数据分治)
题意 链接 Sol \(10^5\)次询问每次询问\(10^5\)个区间..这种题第一感觉就是根号/数据分治的模型. \(K\)是个定值这个很关键. 考虑\(K\)比较小的情况,可以直接暴力建SAM, ...
- 2018-06-21 中文代码示例视频演示Python入门教程第五章 数据结构
知乎原链 续前作: 中文代码示例视频演示Python入门教程第四章 控制流 对应在线文档: 5. Data Structures 这一章起初还是采取了尽量与原例程相近的汉化方式, 但有些语义较偏(如T ...
- CentOS 安装 jdk
1.首下载CentOS对应的jdk压缩包. 2.通过secureCRT工具远程连接目标服务器. 3.通过rz命令上传jdk压缩包到linux服务器. 4.解压缩上传的jdk压缩包 tar -zxvf ...
- 【代码笔记】Web-JavaScript-Javascript对象
一,效果图. 二,代码. <!DOCTYPE html> <html> <head> <meta charset="utf-8"> ...
- <自动化测试方案_5>第五章、代码单元自动化测试
第五章.代码单元自动化测试 代码单元测试需要根据编程语言,选择单元测试框架,然后访问类方法,函数.代码单元测试做自动化,相比API.UI自动化做起来更加麻烦,建议放到待API自动化测试.UI自动化测试 ...
- $.ajax({})方法中的回调函数beforeSend,success,complete,error使用示例
在与后台交互的时候,经常使用到jquery的$.ajax()方法来请求数据.回调函数用的比较多的是success,但是beforeSend.complete.error函数也是很有用的.下面是使用例子 ...