C++实现简单走迷宫的代码

640?wx_fmt=gif

用n*n个小方格代表迷宫,每个方格上有一个字符0或1,0代表这个格子不能走,1代表这个格子可以走。只能一个格子一个走,而且只能从一个格子向它的上、下、左、右四个方向走,且不能重复。迷宫的入口和出口分别位于左上角和右下角,存在唯一的一条路径能够从入口到达出口,试着找出这条路径。

例如,下图是一个迷宫,红色表示走出迷宫的一条路径

640?wx_fmt=jpeg

输入:入口坐标(startX,startY),出口坐标(endX,endY)

思路:利用回溯法求解。

代码实现如下:

#include <iostream>	
#include <vector>	
using namespace std;	class Solution {	
public:	bool hasPath(char* matrix, int rows, int cols, int startX,int startY, int endX, int endY,vector<int>& Path)	
{	if (matrix == NULL || rows < 1 || cols < 1 || startX<0||startY<0||endX<0||endY<0||(startX==endX&&startY==endY))	return false;	bool* visited = new bool[rows*cols];       //定义一个辅助矩阵,用来标记路径是否已经进入了每个格子	memset(visited, 0, rows*cols);	int pathLength = 0;	if (hasPathCore(matrix, rows, cols, startX, startY, endX, endY, visited, Path))	{	return true;	}	delete[] visited;	return false;	}	/*此函数用来判断在当前路径满足条件下,相邻格子中是否存在一个格子满足条件*/	bool hasPathCore(char* matrix, int rows, int cols, int row, int col, int endX, int endY, bool* visited, vector<int>& Path)	
{	if ((row == endX) && (col == endY)&&(matrix[row*cols+col]=='1'))	{	Path.push_back(endY);	Path.push_back(endX);	return true;	}	bool hasPath = false;	if (row >= 0 && row < rows&&col >= 0 && col < cols&&matrix[row*cols + col] == '1' && !visited[row*cols + col])	{	
//     ++pathLength;	visited[row*cols + col] = true;	Path.push_back(col);	Path.push_back(row);	/*如果矩阵格子(row,col)字符为1时,从它的4个相邻格子中寻找下一个字符为1的格子*/	hasPath = hasPathCore(matrix, rows, cols, row, col - 1, endX, endY, visited,Path) ||	hasPathCore(matrix, rows, cols, row - 1, col, endX, endY, visited,Path) ||	hasPathCore(matrix, rows, cols, row, col + 1, endX, endY, visited,Path) ||	hasPathCore(matrix, rows, cols, row + 1, col, endX, endY, visited,Path);	if (!hasPath)               //如果没找到,则说明当前第n个格子定位不正确,返回上一个位置重新定位	{	visited[row*cols + col] = false;	Path.pop_back();	Path.pop_back();	}	}	return hasPath;	}	
};	int main()	
{	// char* matrix = "abcesfcsadee";	char* matrix = "1000000110110001101000010111011110100000010000001";    //设置迷宫	int startX, startY, endX, endY;	cin >> startX >> startY >> endX >> endY;                  //输入起始结束坐标	Solution s;	vector<int> Path;	bool re = s.hasPath(matrix, 7, 7, startX,startY,endX,endY,Path);	cout << re << endl;	for (int i = 0; i < Path.size();)	cout << "(" << Path[i++] << ',' << Path[i++] << ")" << " ";	cout << endl;	return 0;	
}

640?wx_fmt=png

640?wx_fmt=png

它,

不仅仅是一个码

扫码关注

C++资源免费送

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/339350.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php实现文本替换,php文本替换 函数 strtr()、str_repalce()

php 中替换函数主要有strtr(),str_repalce()这两个函数,但你们都知道他们这两个函数的区别和用法吗?IT我领先在这里给大家一个实例来说明这一问题.先来看看这个php字符串替换函数 strtr()的两种用法:strtr(string,from,to)或者strtr(string,array)首先针对strtr函数第一种方式…

lucene使用3.0.3_Apache Lucene 5.0.0即将发布!

lucene使用3.0.3终于,在一系列强大的4.x功能(最近是4.10.2)发布之后,我们终于在努力开发另一个主要的Apache Lucene版本! 没有确切时间的承诺(完成时就完成了!),但是我们…

利用C/C++实现较完整贪吃蛇游戏

利用空余时间写出了这么一个简单的小游戏,直接使用dos界面运行。那么问题来了,如何让一个字符在dos界面上自由移动???对于这个问题我采用的解决方案是实现gotoxy函数来控制指针位置从而实现字符的移动。那么我们就先来…

php跳转到另外一个方法,PHP 页面跳转到另一个页面的多种方法方法总结

PHP 页面跳转到另一个页面的多种方法方法总结一用 HTTP 头信息也就是用 PHP 的 HEADER 函数 PHP 里的 HEADER 函数的作用就是向浏览器发出由 HTTP 协议规定的本来应该通过 web 服务器的控制指令, 例如声明返回信息的类型 ("Context-type: xxx/xxx"), 页面的属性(&quo…

java 泛型和类型擦除_关于Java泛型和擦除

java 泛型和类型擦除“编译期间擦除泛型”是常识&#xff08;好吧&#xff0c;类型参数和实参实际上是被擦除的&#xff09;。 这是由于“类型擦除”而发生的。 但这是错误的&#xff0c;正如许多开发人员所假设的那样&#xff0c;将<..>符号内指定的所有内容都删除了。 …

PHP中文无法查询,php 中htmlentities导致中文无法查询问题

在php中htmlspecialchars&#xff0c; 将特殊字元转成 HTML 格式,而htmlentities&#xff0c;将所有的字元都转成 HTML 字串 了&#xff0c;下面我来分别简单的介绍。htmlentities用法$str "John & Adams";echo htmlentities($str, ENT_COMPAT);echo "&quo…

C++中的函数汇总(新手必知)!

math.h 数学函数库,一些数学计算的公式的具体实现是放在math.h里,具体有&#xff1a;1 三角函数double sin (double); double cos (double); double tan (double);2 反三角函数double asin (double); 结果介于[-PI/2, PI/2] double acos (double); 结果介于[0, PI] double …

艾伦图灵_Java英雄:丹·艾伦

艾伦图灵“ Java英雄 ”系列休息了很长时间。 老实说&#xff0c;我想即使有很多人我想把它包括在这里&#xff0c;它也可能会在茫茫荒野中终结。 丹是其中之一。 我第一次要求他捐款已经差不多一年半了&#xff0c;并且在此期间发生的所有事情使我安然无not。 但是以下内容在J…

26条C++的经典语录,哪几句戳中你的心!

2019年悄悄的已经过了三分之二&#xff0c;C你了解了多少&#xff1f;随着互联网的发展&#xff0c;c作为底层语言的龙头老大&#xff0c;是时候站出来了&#xff01;如何学好C,老夫我利用平生所学&#xff0c;整理出26条C经典语录&#xff0c;希望能帮助到每一个热爱C的同学&a…

java打印等边三角市,java 打印菱形和等边三角形

public class PrintJava {public static void print(int n){for(int i 1;i<n;i){for(int k n-1;k>i;k–){System.out.print(” “);}for(int j 1;j<2*i-1;j){System.out.print(“*”);}System.out.println(“”);}for(int i n-1 ;i>0;i–){for(int k 1;k<n…

java 科学计数_Java和甜蜜的科学

java 科学计数当您使用Java进行开发已有15年之久&#xff0c;并且一位同事要求您帮助他们调试空指针异常时&#xff0c;您不会感到惊讶。 通常&#xff0c;很明显什么是null&#xff0c;唯一要做的就是找出原因。 有时会有些困难&#xff0c;因为有人创建了一系列取消引用的对…

C语言的10大基础算法

算法是一个程序和软件的灵魂&#xff0c;作为一名优秀的程序员&#xff0c;只有对一些基础的算法有着全面的掌握&#xff0c;才会在设计程序和编写代码的过程中显得得心应手。本文是近百个C语言算法系列的第二篇&#xff0c;包括了经典的Fibonacci数列、简易计算器、回文检查、…

Java的文件流定义,java文件流的问题!急

朋友你好&#xff0c;用使用 javadoc 标记可以做到。具体说明如下&#xff1a;&#xff1a;javadoc 标记是插入文档注释中的特殊标记&#xff0c;它们用于标识代码中的特殊引用。javadoc 标记由“”及其后所跟的标记类型和专用注释引用组成。记住了&#xff0c;三个部分——、标…

sprint boot_Sprint Boot子战争包装

sprint bootSpring Boot建议在构建期间使用嵌入式容器&#xff08;tomcat或码头&#xff09;创建一个可执行jar&#xff0c;并在运行时将此可执行jar作为独立进程使用。 但是&#xff0c;通常将应用程序部署到一个外部容器是很常见的&#xff0c;Spring Boot提供了打包应用程序…

C++实现简单的信息管理系统

本文为大家分享C实现简单的信息管理系统&#xff0c;小编之前在学习的时候也要做一些管理系统&#xff0c;在网上查了许多资料&#xff0c;现在我把资料分享给大家&#xff0c;希望能够帮助到大家。#include <stdio.h> #include <stdlib.h> #include "file.…

php 多图上传编辑器,ThinkPHP5整合LayUI编辑器图片上传

一、创建上传方法public function uploadimg(){$image $_FILES[file];$filebase file_get_contents($image[tmp_name]);$upimg $this->uploadImage($filebase);$upfile[code] 0;$upfile[msg] 上传成功;$upfile[data][src] $upimg;$upfile[data][title] $image[name];…

jaxb_JAXB众所周知的秘密

jaxb介绍 我重新发现了Java向大众提供的库。 当我第一次阅读该规范时&#xff0c;我很困惑&#xff0c;以为我需要所有这些特殊工具来实现。 我最近发现&#xff0c;只需要一些注释和一个POJO。 杰克斯 JAXB代表XML绑定的Java体系结构。 这种体系结构允许开发人员将来自类的数…

C# 面向对象三大特性:封装、继承、多态

面向对象有封装、继承、多态这三个特性&#xff0c;面向对象编程按照现实世界的特点来管理复杂的事物&#xff0c;把它们抽象为对象&#xff0c;具有自己的状态和行为&#xff0c;通过对消息的反应来完成任务。这种编程方法提供了非常强大的多样性&#xff0c;大大增加了代码的…

行车记录仪设置php,行车记录仪怎么调设置

行车记录仪设置方法如下&#xff1b;1、视频分辨率视频分辨率一直是厂家着力宣传的卖点&#xff0c;从最初的高清720P、全高清1080P到现在的超高清2K&#xff0c;车主朋友们也都耳熟能详。一般行车记录仪的分辨率提供以下几个选项&#xff1a;1080FHD、720P、WVGA、VGA。视频分…

gtest 测试部分_全部关于测试–第2部分

gtest 测试部分这是有关测试的系列文章的第二篇。 在第一部分中&#xff0c;我解释了在开发测试时需要具备的心态。 或者&#xff0c;换句话说&#xff0c;开发可测试的代码。 在这一部分中&#xff0c;我将介绍一些测试方法的技术。 我将描述的技术可以看作是如何将思维定势转…