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

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

相关文章

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想

Python中Windows和macOS文件路径格式不一致的解决方法

《Python中Windows和macOS文件路径格式不一致的解决方法》在Python中,Windows和macOS的文件路径字符串格式不一致主要体现在路径分隔符上,这种差异可能导致跨平台代码在处理文... 目录方法 1:使用 os.path 模块方法 2:使用 pathlib 模块(推荐)方法 3:统一使

一文教你解决Python不支持中文路径的问题

《一文教你解决Python不支持中文路径的问题》Python是一种广泛使用的高级编程语言,然而在处理包含中文字符的文件路径时,Python有时会表现出一些不友好的行为,下面小编就来为大家介绍一下具体的... 目录问题背景解决方案1. 设置正确的文件编码2. 使用pathlib模块3. 转换路径为Unicod

SpringBoot自定义注解如何解决公共字段填充问题

《SpringBoot自定义注解如何解决公共字段填充问题》本文介绍了在系统开发中,如何使用AOP切面编程实现公共字段自动填充的功能,从而简化代码,通过自定义注解和切面类,可以统一处理创建时间和修改时间... 目录1.1 问题分析1.2 实现思路1.3 代码开发1.3.1 步骤一1.3.2 步骤二1.3.3

MySQL9.0默认路径安装下重置root密码

《MySQL9.0默认路径安装下重置root密码》本文主要介绍了MySQL9.0默认路径安装下重置root密码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录问题描述环境描述解决方法正常模式下修改密码报错原因问题描述mysqlChina编程采用默认安装路径,

Go Mongox轻松实现MongoDB的时间字段自动填充

《GoMongox轻松实现MongoDB的时间字段自动填充》这篇文章主要为大家详细介绍了Go语言如何使用mongox库,在插入和更新数据时自动填充时间字段,从而提升开发效率并减少重复代码,需要的可以... 目录前言时间字段填充规则Mongox 的安装使用 Mongox 进行插入操作使用 Mongox 进行更

基于Java实现模板填充Word

《基于Java实现模板填充Word》这篇文章主要为大家详细介绍了如何用Java实现按产品经理提供的Word模板填充数据,并以word或pdf形式导出,有需要的小伙伴可以参考一下... Java实现按模板填充wor编程d本文讲解的需求是:我们需要把数据库中的某些数据按照 产品经理提供的 word模板,把数据

python获取当前文件和目录路径的方法详解

《python获取当前文件和目录路径的方法详解》:本文主要介绍Python中获取当前文件路径和目录的方法,包括使用__file__关键字、os.path.abspath、os.path.realp... 目录1、获取当前文件路径2、获取当前文件所在目录3、os.path.abspath和os.path.re

hdu2544(单源最短路径)

模板题: //题意:求1到n的最短路径,模板题#include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#i