- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这个小程序应该打印出迷宫中所有可能的路线,入口/起点总是从左上角向下一个,所有可能的导出总是在右墙上。它从文本文件中检索迷宫。
迷宫其实就是一堆文字。迷宫由 n x n 网格组成,由作为墙壁的“#”符号和代表可步行区域/路径的各种字母 [a...z] 组成。字母可以重复,但永远不能并排。
迷宫大小为 15x15。
大写的 S 始终标示入口,位于左墙上第二高的位置。一条可能的路径只能通过字母——你不能在 # 符号上行走。右墙上的任何字母代表导出。
例如,
######
Sa#hln
#bdp##
##e#ko
#gfij#
######
是一个可能的迷宫。我的小程序应该在读取实际包含迷宫的文本文件后打印出所有可能的路线。
对该程序的调用将在屏幕上生成以下输出:
Path 1: S,a,b,d,e,f,i,j,k,o
Path 2: S,a,b,d,p,h,l,n
2 total paths
我会怎么做呢?我不需要完整的代码答案,我只需要有关如何解决此问题的一些指导。
到目前为止,除了递归检查相邻方 block 以查看您是否可以在其上行走的实际算法本身之外,我已经完成了所有工作,而且我不知道如何在多条路径上工作。
这是我目前所做的(我知道我的路径检查是错误的,但我不知道还能做什么):
#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include <sstream>
#include <cstdio>
using namespace std;
ifstream file("maze.txt");
vector<char> vec(istreambuf_iterator<char>(file), (istreambuf_iterator<char>())); // Imports characters from file
vector<char> path; // Declares path as the vector storing the characters from the file
int x = 18; // Declaring x as 18 so I can use it with recursion below
char entrance = vec.at(16); // 'S', the entrance to the maze
char firstsquare = vec.at(17); // For the first walkable square next to the entrance
vector<char> visited; // Squares that we've walked over already
int main()
{
if (file) {
path.push_back(entrance); // Store 'S', the entrance character, into vector 'path'
path.push_back(firstsquare); // Store the character of the square to the right of the entrance
// into vector 'path'.
while (isalpha(vec.at(x)))
{
path.push_back(vec.at(x));
x++;
}
cout << "Path is: "; // Printing to screen the first part of our statement
// This loop to print to the screen all the contents of the vector 'path'.
for(vector<char>::const_iterator i = path.begin(); i != path.end(); ++i) //
{
std::cout << *i << ' ';
}
cout << endl;
system ("pause"); // Keeps the black box that pops up, open, so we can see results.
return 0;
}
}
谢谢!
最佳答案
您需要做一些事情才能开始:
考虑从一个小得多的迷宫开始——也许是一个 3x3 大小的迷宫——有一条直接穿过 map 的路径。你的程序应该能够解决这个问题。然后将路径更改为曲线一点。然后把 map 放大。让道路更艰难。在路径上放一些“红鲱鱼”分支。
map 越小,越复杂,调试起来应该会容易得多。 (如果您不知道如何使用调试器,从一个小问题入手将使学习调试器更容易。)
祝你好运!
关于C++ "Maze"赋值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10730447/
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 5年前关闭。 Improve this questi
我正在尝试创建一个程序,该程序将遍历一个随机生成的迷宫,其中 1 是开放的,0 是墙壁。从左上角开始,到右下角结束。该路径可以向上、向下、向左、向右。 目前,我的程序为我提供了一种解决方案,但我无法让
这个小程序应该打印出迷宫中所有可能的路线,入口/起点总是从左上角向下一个,所有可能的导出总是在右墙上。它从文本文件中检索迷宫。 迷宫其实就是一堆文字。迷宫由 n x n 网格组成,由作为墙壁的“#”符
解迷宫的可能方法有哪些? 我有两个想法,但我认为它们不是很优雅。 基本情况:我们有一个矩阵,这个矩阵中的元素以一种表示迷宫的方式排序,有一条进路和一条出路。 我的第一个想法是让机器人沿着迷宫的一侧穿过
首先让我为尺寸道歉我会尽量保持它尽可能小 在尝试完全按照维基百科上所说的那样构建 prim 的算法后,我发现它无法按照我构建的迷宫方式运行。所以我尝试做同样的想法来适应我的迷宫,但我看到了一个奇怪的错
所以我的任务是创建一个迷宫解算器,其中包含一个队列、一个集合、一个位置对象和最终形成一个迷宫对象的单元格对象。 快速浏览一下我完成后所有代码的基本功能: 7 10 _ _ _ _ _ _ _ _
题目地址:https://leetcode-cn.com/problems/the-maze-ii/ 题目描述 There is a ball in a maze with empty space
我的问题本质上是对递归的怀疑。我正在解决经典的“迷宫中的老鼠”DFS 遍历问题。我的输入是一个 n*n int 数组 a[][],其中索引 i 和 j,a[i][j] 可以是 0 或 1。 0 表示假
我正在尝试为一个迷宫创建一个 BFS,该迷宫将在到达某个点时停止。在测试它时,我遇到了段错误(核心转储)错误。我正在尝试修改我在此 site 上找到的代码.我正在尝试做的事情与该站点中的代码之间的主要
我正在编写代码以读取代表“迷宫”的文件中的 7x15 文本 block 。 #include #include #include #include "board.h" int main() {
我正在开发一个合作伙伴项目,我的合作伙伴为游戏创建一个解算器类,而我的部分是创建 MazeGUI。 当您单击 Solve JButton 时,它应该突出显示它在 GUI 本身上所采取的路径,但它只突出
这个问题已经有答案了: What is a NullPointerException, and how do I fix it? (12 个回答) 已关闭 7 年前。 我正在尝试使用 DisjSet
我一直在研究代码 war ,并且遇到了 mazerunner (https://www.codewars.com/kata/maze-runner/train/javascript),我已经被难住了大
我的目标是生成一个由 Cell 对象的二维数组组成的迷宫。下面是单元格和迷宫的代码。使用调试器我可以看到 boolean 值正在改变,并且生成按预期进行,但是当它得到打印时,没有路径。所有的墙都还在原
运行时检查失败 #2 变量“迷宫”周围的堆栈已损坏。每当我编译并运行我的程序时,只要程序完成运行,我就会收到此错误。我相信问题出在我的实现中的 addPaths 函数中。为了以防万一,我发布了所有代码
所以我在学习 C++ 的同时正在做学校作业。我不是在寻找给我的代码,而是在帮助理解/提出解决这个问题的正确算法。 我需要创建一个由 1 和 0 组成的 (5x5x5) 3d 迷宫。随机填充它(除了 0
我想创建一个带有迷宫(不是真的)的游戏。整个 map 应该被墙包围,而在这些墙内应该有一个迷宫。这个迷宫应该是随机创建的。在没有放置墙的每一 block 瓷砖上,玩家应该随机放置。 SpriteKit
我最近出现在一个工作面试中,我被问到一个流行的 RAT IN A MAZE 问题,其中有一个由二维数组表示的迷宫,其中分别包含 0 和 1 表示开放路径和墙壁,我们必须打印最短的路径。 我使用回溯法解
我最近一直在尝试在 Haskell 中创建一个迷宫求解器,并且我已经设法拼凑出一个大部分可用的算法。但是,我不知道如何确定给定的迷宫是否无法解决。 solveMazeQuickly :: Maze -
我尝试随机生成一个迷宫,但在编译下面的程序时出现段错误 这是代码 void spread(int v, int x, int y, int *t,int w, int *count){ //t
我是一名优秀的程序员,十分优秀!