0

0

C++迷宫生成算法 深度优先随机生成

P粉602998670

P粉602998670

发布时间:2025-08-26 12:07:01

|

825人浏览过

|

来源于php中文网

原创

答案:使用DFS结合随机性生成迷宫,从起点开始标记访问,随机打乱方向顺序,打通相邻未访问格子间的墙并递归探索,最终形成连通无环的迷宫结构。

c++迷宫生成算法 深度优先随机生成

用深度优先搜索(DFS)结合随机性来生成迷宫,是一种常见且效果不错的算法。核心思路是模拟“回溯探索”的过程,从起点出发,随机选择未访问的方向前进,打通墙壁,直到所有格子都被访问过,形成一个连通无环的迷宫。

算法基本原理

将迷宫看作一个二维网格,每个格子是一个“房间”。通过打破格子之间的墙来连接它们。使用深度优先搜索,但每次选择下一个方向时采用随机顺序,这样可以生成结构多变的迷宫。

关键点:

  • 从任意起点开始(通常选左上角)
  • 标记当前格子为已访问
  • 随机打乱上下左右四个方向的探索顺序
  • 对每个方向,若相邻格子未访问,则打通中间的墙,递归进入该格子
  • 使用栈或递归实现回溯

代码实现(递归版本)

#include 
#include 
#include 
#include 
#include 

using namespace std;

const int WIDTH = 21;  // 宽度必须为奇数,方便表示墙和格子
const int HEIGHT = 21; // 高度也必须为奇数

vector> visited(HEIGHT, vector(WIDTH, false));
vector> maze(HEIGHT, vector(WIDTH, true)); // true 表示墙

// 四个方向:上、右、下、左
int dx[4] = {0, 2, 0, -2};
int dy[4] = {-2, 0, 2, 0};

void generate(int x, int y) {
    visited[y][x] = true;
    maze[y][x] = false; // 当前格子设为通路

    // 定义方向索引并随机打乱
    vector dirs = {0, 1, 2, 3};
    random_shuffle(dirs.begin(), dirs.end());

    for (int i : dirs) {
        int nx = x + dx[i];
        int ny = y + dy[i];

        if (nx > 0 && nx < WIDTH-1 && ny > 0 && ny < HEIGHT-1 && !visited[ny][nx]) {
            maze[ny + dy[i]/2][nx + dx[i]/2] = false; // 打通中间墙
            generate(nx, ny);
        }
    }
}

void printMaze() {
    for (int i = 0; i < HEIGHT; ++i) {
        for (int j = 0; j < WIDTH; ++j) {
            cout << (maze[i][j] ? "#" : " ");
        }
        cout << endl;
    }
}

int main() {
    srand(time(0));

    // 起点设在 (1,1)
    generate(1, 1);

    // 可选:设置入口和出口
    maze[0][1] = false;
    maze[HEIGHT-1][WIDTH-2] = false;

    printMaze();

    return 0;
}

关键细节说明

网格尺寸为何是奇数? 因为每个格子之间有墙,若用 21x21 的网格,实际表示 10x10 个房间,墙和通路交错分布。坐标 (1,1)、(1,3) 等为房间位置,偶数坐标多为墙。

立即学习C++免费学习笔记(深入)”;

网趣网上购物系统HTML静态版
网趣网上购物系统HTML静态版

网趣购物系统静态版支持网站一键静态生成,采用动态进度条模式生成静态,生成过程更加清晰明确,商品管理上增加淘宝数据包导入功能,与淘宝数据同步更新!采用领先的AJAX+XML相融技术,速度更快更高效!系统进行了大量的实用性更新,如优化核心算法、增加商品图片批量上传、谷歌地图浏览插入等,静态版独特的生成算法技术使静态生成过程可随意掌控,从而可以大大减轻服务器的负担,结合多种强大的SEO优化方式于一体,使

下载

如何打通墙? 从 (x,y) 走到 (x+2,y),中间墙在 (x+1,y),所以将该位置设为 false。

random_shuffle 提升随机性 每次随机打乱方向顺序,避免固定模式,让迷宫更自然。

递归深度问题 大迷宫可能导致栈溢出。可改用显式栈迭代实现,逻辑一致但更安全。

基本上就这些。算法简单,生成的迷宫连通性好,适合游戏或演示使用。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

371

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

563

2023.08.10

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

389

2023.08.14

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

65

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

45

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

40

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

41

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

232

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

9

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号