我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Matlab利用prim算法实现迷宫的生成

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Matlab利用prim算法实现迷宫的生成

最近比较忙更新频率也慢了下来,今天带来一个比较有趣的可视化,基于prim算法的迷宫生成并用距离生成图片:

我通过各种向量化编程编写了一个迷宫生成函数,由于代码不是很短因此放在最后面展示代码,以下展示如果将最前面的参数进行改变会有啥效果。

代码使用

迷宫生成

迷宫生成就是用的非常简单的prim算法,大体就是不断的在已经开过门的房间四周随机选择紧挨着的房间,直到所有房间被开过。我的代码编写是专门弄了五个矩阵,一个存已经到过的房间,另外四个分别存上下左右打开过的围墙。

如果代码最前面的基础信息设置为:

% 地图基础信息设置
mazeSize=[30,30];
SPos=[2,5];
showMap=true;
showSurf=false;

就意味着绘制30x30个房间,从第二行第五个房间开始开门,展示迷宫但是不展示距离映射。

当然设置其他大小和其他起点也可以:

映射图

将到起点的距离映射为颜色,只需要将前面的showSurf更改为true:

% 地图基础信息设置
mazeSize=[30,30];
SPos=[2,5];
showMap=true;
showSurf=true;

当然如果设置的地图较大,建议将showMap设置为false,不然绘制的太慢了:

mazeSize=[200,200];
SPos=[50,50];
showMap=false;
showSurf=true;

当然如果把74多行的colormap改成其他颜色,比如pink、bone、turbo、colorcube:

当然colormap可以自己设置的更复杂:

% 自定义色带
if 1
Cmap=[89,214,179
140,181,195
177,156,206
241,189,239
215,193,244
178,199,253
140,189,234
145,166,229
106,85,202]./255;
Ci=1:size(Cmap,1);Cq=linspace(1,size(Cmap,1),300);
Cmap=[interp1(Ci,Cmap(:,1),Cq,'linear')',...
     interp1(Ci,Cmap(:,2),Cq,'linear')',...
     interp1(Ci,Cmap(:,3),Cq,'linear')'];
colormap(Cmap)
end

多起点

值得一提的是,多个起点也是支持的!!

% 地图基础信息设置
mazeSize=[30,30];
SPos=[2,5;20,15];
showMap=true;
showSurf=true;

依旧可以设置颜色和更大的地图:

当然不建议将大小设置为300x300以上,???什么玩意这么香????嗷原来是我的电脑!!

完整代码

function primMaze
% @author : slandarer
% 公众号  : slandarer随笔
% 知乎    : 已由hikari更名slandarer

% 地图基础信息设置
mazeSize=[50,50];
SPos=[2,5];
showMap=true;
showSurf=true;

% 初始化可达迷宫及上下左右围墙矩阵
mazeMat=ones(mazeSize);
mazeMat(sub2ind(mazeSize,SPos(:,1),SPos(:,2)))=0;
zerosMat=zeros(mazeSize);
disMat=zeros(mazeSize);
[UMat,DMat,LMat,RMat]=...
    deal(ones(mazeSize),ones(mazeSize),ones(mazeSize),ones(mazeSize));

if showMap
    wallHdl=drawMap(UMat,DMat,LMat,RMat);
end

while any(any(mazeMat))
    % 找到全部已经走到过且周围至少有一个门的房间
    UMazeMat=zerosMat;UMazeMat(2:end,:)=mazeMat(1:end-1,:);
    DMazeMat=zerosMat;DMazeMat(1:end-1,:)=mazeMat(2:end,:);
    LMazeMat=zerosMat;LMazeMat(:,2:end)=mazeMat(:,1:end-1);
    RMazeMat=zerosMat;RMazeMat(:,1:end-1)=mazeMat(:,2:end);
    maze4Mat=UMazeMat+DMazeMat+LMazeMat+RMazeMat;
    [acRow,acCol]=find(mazeMat==0&maze4Mat>0);
    % 随机选择一个当前已经走到过的房间
    tempInd=randi(size(acRow,1),[1,1]);
    tempRow=acRow(tempInd);
    tempCol=acCol(tempInd);
    % 删掉地图外房间位置和不可达房间位置
    nextPos=[tempRow,tempCol]+[-1,0;1,0;0,-1;0,1];
    nextPos(nextPos(:,1)<1,:)=[];
    nextPos(nextPos(:,2)<1,:)=[];
    nextPos(nextPos(:,1)>mazeSize(1),:)=[];
    nextPos(nextPos(:,2)>mazeSize(2),:)=[];
    nextBool=mazeMat(sub2ind(mazeSize,nextPos(:,1),nextPos(:,2)))>0;
    nextPos=nextPos(nextBool,:);
    % 随机选择下一个房间
    nextInd=randi(size(nextPos,1),[1,1]);
    nextRow=nextPos(nextInd,1);
    nextCol=nextPos(nextInd,2);
    mazeMat(nextRow,nextCol)=0;
    disMat(nextRow,nextCol)=disMat(tempRow,tempCol)+1;
    % 打破墙壁
    switch true
        case isequal([nextRow,nextCol]-[tempRow,tempCol],[-1,0])
            UMat(tempRow,tempCol)=0;DMat(nextRow,nextCol)=0;
        case isequal([nextRow,nextCol]-[tempRow,tempCol],[1,0])
            DMat(tempRow,tempCol)=0;UMat(nextRow,nextCol)=0;
        case isequal([nextRow,nextCol]-[tempRow,tempCol],[0,-1])
            LMat(tempRow,tempCol)=0;RMat(nextRow,nextCol)=0;
        case isequal([nextRow,nextCol]-[tempRow,tempCol],[0,1])
            RMat(tempRow,tempCol)=0;LMat(nextRow,nextCol)=0;
    end
    % 用来显示地迷宫的代码
    if showMap
    refreshMap(wallHdl,UMat,DMat,LMat,RMat)
    drawnow
    end
end
% =========================================================================
% 绘制颜色映射图
if showSurf
sax=gca;hold on
[sM,sN]=size(UMat);
sax.XLim=[0,sN]+.5;
sax.YLim=[0,sM]+.5;
sax.DataAspectRatio=[1,1,1];
surf(flipud(disMat),'EdgeColor','none')
colormap(pink)

% 自定义色带
if 0
Cmap=[89,214,179
140,181,195
177,156,206
241,189,239
215,193,244
178,199,253
140,189,234
145,166,229
106,85,202]./255;
Ci=1:size(Cmap,1);Cq=linspace(1,size(Cmap,1),300);
Cmap=[interp1(Ci,Cmap(:,1),Cq,'linear')',...
     interp1(Ci,Cmap(:,2),Cq,'linear')',...
     interp1(Ci,Cmap(:,3),Cq,'linear')'];
colormap(Cmap)
end
end
% =========================================================================
% CODE: test drawMap
% UMat(2,3)=0;
% DMat(1,3)=0;
% drawMap(UMat,DMat,LMat,RMat)
    function wallHdl=drawMap(UMat,DMat,LMat,RMat)
        ax=gca;hold on
        [M,N]=size(UMat);
        ax.XLim=[0,N]+.5;
        ax.YLim=[0,M]+.5;
        ax.DataAspectRatio=[1,1,1];
        % 绘制上方围墙
        [Y,X]=find(UMat);Y=M+1-Y;
        X=[X.'+[.5;-.5];nan.*(ones(1,length(X)))];
        Y=[Y.'+[.5;.5];nan.*(ones(1,length(Y)))];
        wallHdl{1}=plot(X(:),Y(:),'LineWidth',1,'Color','k');
        % 绘制下方围墙
        [Y,X]=find(DMat);Y=M+1-Y;
        X=[X.'+[.5;-.5];nan.*(ones(1,length(X)))];
        Y=[Y.'+[-.5;-.5];nan.*(ones(1,length(Y)))];
        wallHdl{2}=plot(X(:),Y(:),'LineWidth',1,'Color','k');
        % 绘制左侧围墙
        [Y,X]=find(LMat);Y=M+1-Y;
        X=[X.'+[-.5;-.5];nan.*(ones(1,length(X)))];
        Y=[Y.'+[.5;-.5];nan.*(ones(1,length(Y)))];
        wallHdl{3}=plot(X(:),Y(:),'LineWidth',1,'Color','k');
        % 绘制右侧围墙
        [Y,X]=find(RMat);Y=M+1-Y;
        X=[X.'+[.5;.5];nan.*(ones(1,length(X)))];
        Y=[Y.'+[.5;-.5];nan.*(ones(1,length(Y)))];
        wallHdl{4}=plot(X(:),Y(:),'LineWidth',1,'Color','k');
    end
% -------------------------------------------------------------------------
    function refreshMap(wallHdl,UMat,DMat,LMat,RMat)
        [M,~]=size(UMat);
        % 绘制上方围墙
        [Y,X]=find(UMat);Y=M+1-Y;
        X=[X.'+[.5;-.5];nan.*(ones(1,length(X)))];
        Y=[Y.'+[.5;.5];nan.*(ones(1,length(Y)))];
        wallHdl{1}.XData=X(:);
        wallHdl{1}.YData=Y(:);
        % 绘制下方围墙
        [Y,X]=find(DMat);Y=M+1-Y;
        X=[X.'+[.5;-.5];nan.*(ones(1,length(X)))];
        Y=[Y.'+[-.5;-.5];nan.*(ones(1,length(Y)))];
        wallHdl{2}.XData=X(:);
        wallHdl{2}.YData=Y(:);
        % 绘制左侧围墙
        [Y,X]=find(LMat);Y=M+1-Y;
        X=[X.'+[-.5;-.5];nan.*(ones(1,length(X)))];
        Y=[Y.'+[.5;-.5];nan.*(ones(1,length(Y)))];
        wallHdl{3}.XData=X(:);
        wallHdl{3}.YData=Y(:);
        % 绘制右侧围墙
        [Y,X]=find(RMat);Y=M+1-Y;
        X=[X.'+[.5;.5];nan.*(ones(1,length(X)))];
        Y=[Y.'+[.5;-.5];nan.*(ones(1,length(Y)))];
        wallHdl{4}.XData=X(:);
        wallHdl{4}.YData=Y(:);
    end
end

以上就是Matlab利用prim算法实现迷宫的生成的详细内容,更多关于Matlab prim算法生成迷宫的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Matlab利用prim算法实现迷宫的生成

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Matlab利用prim算法实现迷宫的生成

普里姆算法(Prim算法),图论中的一种算法,可在加权连通图里搜索最小生成树。本文将利用prim算法迷宫生成及其艺术渲染,感兴趣的可以了解一下
2022-11-13

Python利用Prim算法生成迷宫

普里姆算法(Prim算法),图论中的一种算法,可在加权连通图里搜索最小生成树。这篇文章将利用Prim算法实现迷宫的生成,感兴趣的可以了解一下
2023-01-06

Python Prim算法通过遍历墙实现迷宫的生成

之前,我们在另外一篇文章中使用Prim算法生成了一个完美迷宫,利用的是遍历网格的方法,这一次,我们要教教大家用遍历墙的方法生成,感兴趣的可以收藏一下
2023-01-06

怎么利用Matlab实现迭代适应点算法

本篇内容主要讲解“怎么利用Matlab实现迭代适应点算法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么利用Matlab实现迭代适应点算法”吧!道格拉斯-普克算法(Douglas–
2023-06-29

利用Python实现自动生成小学生计算题

过年期间发现小外甥已经上小学了,我姐说老师今天给他们布置了寒假作业:每天坚持做乘法和加减法混合运算。这我必须帮帮忙,用Python写了一段自动生成小学生计算题的代码,希望外甥不要太感谢我
2023-02-07

利用Python脚本生成sitemap.xml的实现方法

安装lxml首先需要pip install lxml安装lxml库。如果你在ubuntu上遇到了以下错误:#include "libxml/xmlversion.h" compilation terminated. error: comma
2022-06-04

Matlab利用随机森林(RF)算法实现回归预测详解

这篇文章主要为大家详细介绍了Matlab如何利用随机森林(RF)算法实现回归预测,以及自变量重要性排序的操作,感兴趣的小伙伴可以了解一下
2023-02-17

利用python3随机生成中文字符的实现方法

前言 运行环境在Python3.6下,Python2的解决方案网上有很多.,想学习python2实现的朋友们可以参考这篇文章:http://www.lsjlt.com/article/34884.htm,下面来一起看看详细的介绍吧。 第一种
2022-06-04

利用Java实现生成随机数的方法有哪些

利用Java实现生成随机数的方法有哪些?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1、通过System.currentTimeMillis()来获取一个当前时间毫秒数的lon
2023-05-31

python 实现红包随机生成算法的简单实例

实例如下:
#! /usr/bin/python
# -*- coding: utf-8 -*-import random
class CDispatch:def _
2022-06-04

浅谈算法之最小生成树Kruskal的Python实现

目录一、前言二、树是什么三、从图到树四、解决生成问题五、从生成树到最小生成树六、实际问题与代码实现七、结尾一、前言 我们先不讲算法的原理,也不讲一些七七八八的概念,因为对于初学者来说,看到这些术语和概念往往会很头疼。头疼也是正常的,因为无端
2022-06-02

利用node.js实现自动生成前端项目组件的方法详解

本文主要给大家介绍了关于利用node.js实现自动生成前端项目组件的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍: 脚本编写背景写这个小脚本的初衷是,项目本身添加一个组件太繁琐了,比如我想要去建立一个login的组
2022-06-04

利用mysql实现的雪花算法案例

一、为何要用雪花算法 1、问题产生的背景 现如今越来越多的公司都在用分布式、微服务,那么对应的就会针对不同的服务进行数据库拆分,然后当数据量上来的时候也会进行分表,那么随之而来的就是分表以后id的问题。 例如之前单体项目中一个表中的数据主键
2022-05-18

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录