逃出迷宫完整算法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极速搭建局域网文件共享服务器完整指南

《Python极速搭建局域网文件共享服务器完整指南》在办公室或家庭局域网中快速共享文件时,许多人会选择第三方工具或云存储服务,但这些方案往往存在隐私泄露风险或需要复杂配置,下面我们就来看看如何使用Py... 目录一、android基础版:HTTP文件共享的魔法命令1. 一行代码启动HTTP服务器2. 关键参

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

OpenCV在Java中的完整集成指南分享

《OpenCV在Java中的完整集成指南分享》本文详解了在Java中集成OpenCV的方法,涵盖jar包导入、dll配置、JNI路径设置及跨平台兼容性处理,提供了图像处理、特征检测、实时视频分析等应用... 目录1. OpenCV简介与应用领域1.1 OpenCV的诞生与发展1.2 OpenCV的应用领域2

C++中detach的作用、使用场景及注意事项

《C++中detach的作用、使用场景及注意事项》关于C++中的detach,它主要涉及多线程编程中的线程管理,理解detach的作用、使用场景以及注意事项,对于写出高效、安全的多线程程序至关重要,下... 目录一、什么是join()?它的作用是什么?类比一下:二、join()的作用总结三、join()怎么

使用Go实现文件复制的完整流程

《使用Go实现文件复制的完整流程》本案例将实现一个实用的文件操作工具:将一个文件的内容完整复制到另一个文件中,这是文件处理中的常见任务,比如配置文件备份、日志迁移、用户上传文件转存等,文中通过代码示例... 目录案例说明涉及China编程知识点示例代码代码解析示例运行练习扩展小结案例说明我们将通过标准库 os

Java堆转储文件之1.6G大文件处理完整指南

《Java堆转储文件之1.6G大文件处理完整指南》堆转储文件是优化、分析内存消耗的重要工具,:本文主要介绍Java堆转储文件之1.6G大文件处理的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言文件为什么这么大?如何处理这个文件?分析文件内容(推荐)删除文件(如果不需要)查看错误来源如何避

C++中全局变量和局部变量的区别

《C++中全局变量和局部变量的区别》本文主要介绍了C++中全局变量和局部变量的区别,全局变量和局部变量在作用域和生命周期上有显著的区别,下面就来介绍一下,感兴趣的可以了解一下... 目录一、全局变量定义生命周期存储位置代码示例输出二、局部变量定义生命周期存储位置代码示例输出三、全局变量和局部变量的区别作用域

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与