- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
北京科技大学实验报告
学院:经济管理学院 专业:金融工程 班级:金融201
姓名:万世文 学号 实验日期:2021 年 10月 19日
实验名称
上机实验-迷宫
实验目的
由空地和墙组成的迷宫中有一个球。球可以向上(u)下(d)左(l)右(r)四个方向滚动,但在遇到墙壁前不会停止滚动。当球停下时,可以选择下一个方向。
给定球的起始位置,目的地和迷宫,找出让球停在目的地的最短距离和移动方案。距离的定义是球从起始位置(不包括)到目的地(包括)经过的空地个数。如果球无法停在目的地,返回-1。
迷宫由一个0和1的二维数组表示。1表示墙壁,0表示空地。你可以假定宫的边缘都是墙壁。起始位置和目的地的坐标通过行号和列号给出。
实验环境搭建
华为云 鲲鹏计算kc1.large.2 vCPUSs | 4GiB EulerOS
搭建过程
购买云服务器
环境登陆验证
环境成功搭建验证
实验原理
广度优先搜索
实验内容与步骤
问题分析
该问题可视为不断向所有可能方向移动,穷举所有可能到达的地方,若目的地为洞,则检查途经所有地点;若目的地为星,则检查所有移动终点。
算法设计
问题1:目的地为星,当球运动经过星时,球不会停止。
while (球可以走到下一个位置)
{
球移动到下一个位置;
if (目的地是洞 且 球到达目的地)
{
printf(%d\n, step);
return 0;
}
}
问题2:目的地为洞,即当球运动经过洞时,球会掉进洞里。
同上。
问题3:实现测试用例生成程序。
freopen(main.in, w, stdout);
srand((unsigned)time(0));
int m = rand() % 50;
int n = rand() % 50;
printf(%d %d\n, m, n);
vectorvectorint maze(m);
for (size_t i = 0; i m; i++)
{
maze[i].resize(n);
for (size_t j = 0; j n; j++)
{
maze[i][j] = (rand() % 10) 6;
printf(%d , maze[i][j]);
}
printf(\n);
}
int x = rand() % m;
int y = rand() % n;
while (maze[x][y] == 1)
{
x = rand() % m;
y = rand() % n;
}
printf(%d %d\n, x, y);
printf(%d\n, rand() % 2);
x = rand() % m;
y = rand() % n;
while (maze[x][y] == 1)
{
x = rand() % m;
y = rand() % n;
}
printf(%d %d\n, x, y);
开始算法流程图
开始
输入数据
输入数据
起点入队
起点入队
从队中取一个元素
从队中取一个元素
向一个方向移动
向一个方向移动
一直向该方向运动
一直向该方向运动
是目的地为洞且到达目的地
是
目的地为洞且到达目的地
否是否到达该方向终点
否
是否到达该方向终点
否
否
是
是
是目的地为星且到达目的地
是
目的地为星且到达目的地
否
否
达到点入队
达到点入队
否是否遍历完4个方向
否
是否遍历完4个方向
是
是
否队列为空
否
队列为空
是没有找到输出-1输出结果
是
没有找到输出-1
输出结果
结束
结束
算法实现
#include stdio.h
#include vector
#include queue
using namespace std;
int main()
{
freopen(main.in, r, stdin);
vectorvectorint maze;
vectorvectorbool visited;
vectorint start(3);
vectorint end(2);
int n, m, isDestiny; //m行n列
printf(input the row and column\n);
scanf(%d %d, m, n);
maze.resize(m);
visited.resize(m);
printf(input the map\n);
for (size_t i = 0; i m; i++)
{
maze[i].resize(n);
visited[i].resize(n);
for (size_t j = 0; j n; j++)
{
scanf(%d, maze[i][j]
文档评论(0)