华为云实验报告.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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)

189****7346 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档