迷宫 填充法新思路(填充干扰路径)

2024-06-15 20:32

本文主要是介绍迷宫 填充法新思路(填充干扰路径),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

#include<iostream>
#include<string>
using namespace std;
#define n 8int * filler=new int[n*n];//记录填充位置int initFiller(){//初始化填充记录器int i,j;for(i=0;i<n;i++){for(j=0;j<n;j++){*(filler+n*i+j)=0;}}return 0;
}int * createMaze(){//初始化迷宫int i,j;int * a;a=new int[n*n];for(i=0;i<n;i++){for(j=0;j<n;j++){*(a+n*i+j)=-1;//不设置为0的原因是超过矩阵范围的位置}				//系统默认的是0,会引起麻烦}*(a+n*0+1)=3;*(a+n*1+1)=1;*(a+n*1+2)=1;*(a+n*1+3)=1;*(a+n*1+5)=1;*(a+n*2+3)=1;*(a+n*2+5)=1;*(a+n*2+6)=1;*(a+n*3+1)=1;*(a+n*3+2)=1;*(a+n*3+3)=1;*(a+n*3+4)=1;*(a+n*3+5)=1;*(a+n*4+1)=1;*(a+n*4+4)=1;*(a+n*5+1)=1;*(a+n*5+2)=1;*(a+n*5+4)=1;*(a+n*5+5)=1;*(a+n*5+6)=1;*(a+n*6+2)=1;*(a+n*6+3)=1;*(a+n*6+4)=1;*(a+n*6+6)=1;*(a+n*7+6)=1;return a;
}void printMaze(int * a){//打印迷宫int i,j;for(i=0;i<n;i++){for(j=0;j<n;j++){if(*(a+n*i+j)==1||*(a+n*i+j)==2){cout<<"  ";}else if(*(a+n*i+j)==3){cout<<"★";}else{//*(a+n*i+j)==-1if(*(filler+n*i+j)==1){//后面变成的-1(填充的位置)cout<<"  ";//后来填充的位置设置为不可见}else{//本来就是-1cout<<"■";}}}cout<<endl;}
}int fillInterferePath(int * a){//填充干扰路径int i,j;int * record=new int[n*n];//辅助int flag=0;//设置flag用来判断什么时候终止循环while(flag==0){//用while循环的意义在于通过反复扫描矩阵实现循环填充,以此将所有干扰路径全部填充for(i=0;i<n;i++){for(j=0;j<n;j++){*(record+n*i+j)=*(filler+n*i+j);if(*(a+n*i+j)==1&&*(a+n*i+j-1)==-1&&*(a+n*(i-1)+j)==-1&&*(a+n*(i+1)+j)==-1//为品字形的四个方向||*(a+n*i+j)==1&&*(a+n*i+j-1)==-1&&*(a+n*(i-1)+j)==-1&&*(a+n*i+j+1)==-1||*(a+n*i+j)==1&&*(a+n*i+j+1)==-1&&*(a+n*(i-1)+j)==-1&&*(a+n*(i+1)+j)==-1||*(a+n*i+j)==1&&*(a+n*i+j-1)==-1&&*(a+n*i+j+1)==-1&&*(a+n*(i+1)+j)==-1){*(a+n*i+j)=-1;//将所有品字形路径全部填充,因为这种路径是死路*(filler+n*i+j)=1;}}}flag=1;//当以下两个for循环不再执行时while循环终止for(i=0;i<n;i++){//意义在于用来判断是否还需要进行填充for(j=0;j<n;j++){if(*(record+n*i+j)!=*(filler+n*i+j)){flag=0;}}}}return 0;
}void run(int * a,char ch){int i,j;for(i=0;i<n;i++){for(j=0;j<n;j++){if(*(a+n*i+j)==3){switch(ch){case 'w':if(*(a+n*(i-1)+j)==1){//将其限定在通道内*(a+n*i+j)=2;//不走回头路*(a+n*(i-1)+j)=3;return;}else{return;}case 'a':if(*(a+n*i+j-1)==1){*(a+n*i+j)=2;*(a+n*i+j-1)=3;return;}else{return;}case 's':if(*(a+n*(i+1)+j)==1){*(a+n*i+j)=2;*(a+n*(i+1)+j)=3;}else{return;}case 'd':if(*(a+n*i+j+1)==1){*(a+n*i+j)=2;*(a+n*i+j+1)=3;return;}else{return;}default:return;}}}}
}char getDirection(int * a){//得到方向int i,j;for(i=0;i<n;i++){for(j=0;j<n;j++){if(*(a+n*i+j)==3){if(*(a+n*i+j+1)==1){//*(a+n*(i-1)+j)==1为了将游戏人物限定在通道之内;return 'd';//1为通道,0为障碍物;}else if(*(a+n*(i+1)+j)==1){return 's';}else if(*(a+n*i+j-1)==1){return 'a';}else if(*(a+n*(i-1)+j)==1){return 'w';}}}}
}int setFiller(int * a,int * b){//填充前与填充后进行比较(为了设置填充标记)int i,j;for(i=0;i<n;i++){for(j=0;j<n;j++){if(*(a+n*i+j)!=*(b+n*i+j)){*(filler+n*i+j)=1;//把进行了填充的位置标记起来}}}return 0;
}int * evaluate(int * a){//深拷贝赋值int * b;b=new int[n*n];int i,j;for(i=0;i<n;i++){for(j=0;j<n;j++){*(b+n*i+j)=*(a+n*i+j);}}return b;
}//仅实用于通道宽度为1的迷宫,若有些迷宫通道宽
//度大于等于2,该算法有时可能无法处理
int handle(){int * a, * b;int count=1;string step;//用string是为了避免用户多输入字符而引起错误initFiller();a=createMaze();b=evaluate(a);//把a的值依次赋给bfillInterferePath(a);//填充干扰路径setFiller(a,b);printMaze(a);cout<<"请按任意键进行下一步!"<<endl;while(*(a+n*7+6)!=3){cout<<"第"<<count<<"步:";cin>>step;run(a,getDirection(a));printMaze(a);count++;}cout<<"恭喜你,顺利到达终点!"<<endl;return 0;
}int main(){handle();return 0;
}

这篇关于迷宫 填充法新思路(填充干扰路径)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

随想录 Day 69 并查集 107. 寻找存在的路径

随想录 Day 69 并查集 107. 寻找存在的路径 理论基础 int n = 1005; // n根据题目中节点数量而定,一般比节点数量大一点就好vector<int> father = vector<int> (n, 0); // C++里的一种数组结构// 并查集初始化void init() {for (int i = 0; i < n; ++i) {father[i] = i;}

SQL Server中,用Restore DataBase把数据库还原到指定的路径

restore database 数据库名 from disk='备份文件路径' with move '数据库文件名' to '数据库文件放置路径', move '日志文件名' to '日志文件存放置路径' Go 如: restore database EaseWe from disk='H:\EaseWe.bak' with move 'Ease

C# 命名管道中客户端访问服务器时,出现“对路径的访问被拒绝”

先还原一下我出现错误的情景:我用C#控制台写了一个命名管道服务器,然后用ASP.NET写了一个客户端访问服务器,运行之后出现了下面的错误: 原因:服务器端的访问权限不够,所以是服务器端的问题,需要增加访问权限。(网上很多都说是文件夹的权限不够,情况不同,不适用于我这种情况) 解决办法: (1)在服务器端相应地方添加以下代码。 PipeSecurity pse = new PipeSec

代码随想录算法训练营第三十九天|62.不同路径 63. 不同路径 II 343.整数拆分 96.不同的二叉搜索树

LeetCode 62.不同路径 题目链接:62.不同路径 踩坑:二维的vector数组需要初始化,否则会报错访问空指针 思路: 确定动态数组的含义:dp[i][j]:到达(i,j)有多少条路经递推公式:dp[i][j] = dp[i-1][j] + dp[i][j-1]初始化动态数组:dp[0][0] = 1遍历顺序:从左到右,从上到下 代码: class Solution {pu

内存填充越界 + malloc空间不够导致越界

【创建时间:2014-11-1 11:50】 [2014-10-31]:环境:系统:Linux版本:3.08    平台:Hisi3516c。 内存填充越界: 问题: 申请了一个2048字节局部静态的变量存储一个固定RGB值,方便后续画框、线时快速copy。但是在第一次赋固定值时,越界了,导致内核自动向应用程序 发送信号 SIGBUS(7)给应用程序,导致应用程序异常

WinCE的C#程序中获取当前应用程序的路径

WinCE中获取当前路径的两种方法: string appPath = System.IO.Path.GetDirectoryName(System.Reflection.Assembly.GetExecutingAssembly().GetName().CodeBase); string appPath = System.IO.Path.GetDirectoryName(System.R

Typora + Hexo 图片路径问题(Typedown)

文章目录 1. 冲突来源2. 解决思路3. 实现1. typora图片路径2. hexo脚本 1. 冲突来源 Hexo上对于图片在md中的引用,使用了post_asset_folder: true配置,来更好的管理图片。 当一篇名为xxx.md的文章引用1.png图片时,默认让1.png保持在xxx文件夹下,那么md中即可使用{% asset_img 1.png %}来引用图片

几大最短路径算法比较

July、二零一一年二月十二日。 -----------------------------------    几个最短路径算法的比较: Floyd        求多源、无负权边的最短路。用矩阵记录图。时效性较差,时间复杂度O(V^3)。        Floyd-Warshall算法(Floyd-Warshall algorithm)是解决任意两点间的最短路径的一

华为od-C卷200分题目3 - 两个字符串间的最短路径问题

华为od-C卷200分题目3 - 两个字符串间的最短路径问题 题目描述 给定两个字符串,分别为字符串A与字符串B。 例如A字符串为ABCABBA,B字符串为CBABAC可以得到下图m*n的二维数组,定义原点为(0, 0),终点为(m, n),水平与垂直的每一条边距离为1,映射成坐标系如下图。 从原点(0, 0)到(0, A)为水平边,距离为1,从(0, A)到(A, C)为垂直边,距离为1