逃出迷宫完整算法C++

2023-12-19 17:48
文章标签 算法 c++ 完整 迷宫 逃出

本文主要是介绍逃出迷宫完整算法C++,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

迷宫图案,白色代表通道,黑色代表墙。
 迷宫入口坐标(1,1),出口坐标(8,8)
  0 1 2 3 4 5 6 7 8 9
  0■■■■■■■■■■
  1■□□■□□□■□■
  2■□□■□□□■□■
  3■□□□□■■□□■
  4■□■■■□□□□■
  5■□□□■□□□□■
  6■□■□□□■□□■
  7■□■■■□■■□■
  8■■□□□□□□□■
  9■■■■■■■■■■

 

程序源代码(VC++ 6.0下编译通过)

#include<iostream>  using namespace std;const int SIZE_X = 10;
const int SIZE_Y = 10;//data structstruct mPoint
{int x;int y;bool can_move_to;mPoint(int rx = 0, int ry = 0, bool rcan_move_to = false){x= rx;y = ry;can_move_to = rcan_move_to;next = NULL;}mPoint* next;
};//function declaration
class mStack
{
public:mStack();//constructorint push(mPoint point);mPoint pop();int getLength();mPoint getTop();void printStack();
private:mPoint *base;//base pointermPoint *top; //top pointerint length; //length of stack
};int main()
{mPoint mpArray[SIZE_X][SIZE_Y];bool initArray[SIZE_X][SIZE_Y]={{ false, false, false, false, false, false, false, false, false, false },{ false, true, true, false, true, true, true, false, true, false },{ false, true, true, false, true, true, true, false, true, false },{ false, true, true, true, true, false, false, true, true, false },{ false, true, false, false, false, true, true, true, true, false },{ false, true, true, true, false, true, true, true, true, false },{ false, true, false, true, true, true, false, true, true, false },{ false, true, false, false, false, true, false, false, true, false },{ false, false, true, true, true, true, true, true, true, false },{ false, false, false, false, false, false, false, false, false, false }};//迷宫矩阵 for(int i = 0; i<SIZE_X;i++){for(int j=0; j<SIZE_Y;j++){mpArray[i][j].x = i;mpArray[i][j].y = j;mpArray[i][j].can_move_to = initArray[i][j];}} mPoint startup(1,1,true);//entrymPoint endp(8,8,true);//exitmStack mpath;mpath.push(startup);mPoint mp = startup;while(true){if(mp.x == endp.x && mp.y == endp.y){break;}if(mpArray[mp.x+1][mp.y].can_move_to){mpArray[mp.x+1][mp.y].can_move_to=false;mpath.push(mPoint(mp.x+1,mp.y));mp = mpArray[mp.x+1][mp.y];continue;}if(mpArray[mp.x-1][mp.y].can_move_to){mpArray[mp.x-1][mp.y].can_move_to=false;mpath.push(mPoint(mp.x-1,mp.y));mp = mpArray[mp.x-1][mp.y];continue;}if(mpArray[mp.x][mp.y+1].can_move_to){mpArray[mp.x][mp.y+1].can_move_to=false;mpath.push(mPoint(mp.x,mp.y+1));mp = mpArray[mp.x][mp.y+1];continue;}if(mpArray[mp.x][mp.y-1].can_move_to){mpArray[mp.x][mp.y-1].can_move_to=false;mpath.push(mPoint(mp.x,mp.y-1));mp = mpArray[mp.x][mp.y-1];continue;}if(0 == mpath.getLength()){cout<<"No path"<<endl;return -1;}mpath.pop();mp = mpath.getTop();}cout<<"Path:"<<endl;mpath.printStack();getchar();return 0;}
mStack::mStack()
{length = 0;base = NULL;top = NULL;
}
int mStack::push(mPoint point)
{mPoint *mpNode = new mPoint();*mpNode = point;if (length == 0)top = base = mpNode;else{top->next = mpNode;top = mpNode;}return ++length;
}
mPoint mStack::getTop()
{return *top;
}
mPoint mStack::pop()
{if (length <= 0)return NULL;mPoint retPoint = *top;top = base;while (top->next != NULL){if (top->next->next == NULL){delete(top->next);top->next = NULL;break;}top = top->next;}if (length == 1){delete(base);base = top = NULL;}length--;return retPoint;
}int mStack::getLength()
{return length;
}
void mStack::printStack()
{mPoint *p = base;while (p != NULL){cout << "(" << p->x << "," << p->y << ")" << endl;p = p->next;}}



本程序堆栈用单向动态链表实现,当然可以用其他数据结构,比如双向链表。

程序输出结果:

Path:
(1,1)
(2,1)
(3,1)
(4,1)
(5,1)
(5,2)
(5,3)
(6,3)
(6,4)
(6,5)
(7,5)
(8,5)
(8,6)
(8,7)
(8,8)

这篇关于逃出迷宫完整算法C++的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/513127

相关文章

Python使用Tkinter打造一个完整的桌面应用

《Python使用Tkinter打造一个完整的桌面应用》在Python生态中,Tkinter就像一把瑞士军刀,它没有花哨的特效,却能快速搭建出实用的图形界面,作为Python自带的标准库,无需安装即可... 目录一、界面搭建:像搭积木一样组合控件二、菜单系统:给应用装上“控制中枢”三、事件驱动:让界面“活”

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

C++/类与对象/默认成员函数@构造函数的用法

《C++/类与对象/默认成员函数@构造函数的用法》:本文主要介绍C++/类与对象/默认成员函数@构造函数的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录名词概念默认成员函数构造函数概念函数特征显示构造函数隐式构造函数总结名词概念默认构造函数:不用传参就可以

C++类和对象之默认成员函数的使用解读

《C++类和对象之默认成员函数的使用解读》:本文主要介绍C++类和对象之默认成员函数的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、默认成员函数有哪些二、各默认成员函数详解默认构造函数析构函数拷贝构造函数拷贝赋值运算符三、默认成员函数的注意事项总结一

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

Apache 高级配置实战之从连接保持到日志分析的完整指南

《Apache高级配置实战之从连接保持到日志分析的完整指南》本文带你从连接保持优化开始,一路走到访问控制和日志管理,最后用AWStats来分析网站数据,对Apache配置日志分析相关知识感兴趣的朋友... 目录Apache 高级配置实战:从连接保持到日志分析的完整指南前言 一、Apache 连接保持 - 性