蓝桥杯13届真题-回忆迷宫(模拟、BFS)
创始人
2024-06-02 06:18:31
0

文章目录

  • 前言
  • 题目
  • 题解
    • 思路
    • 解法1:模拟、BFS
  • 参考资料

前言

本题为蓝桥杯第13届JavaB组省赛真题,分值为20分。

标签:模拟、BFS

  • 模拟:模拟构建地图。
  • BFS:数组队列来bfs二维矩阵。

蓝桥杯第13届JavaB组省赛真题及题解可见博客:第十三届蓝桥杯省赛JavaB组真题(Java题解解析)

本题在线OJ平台:蓝桥杯官网在线OJ-回忆迷宫

题目

image-20230312111436741

image-20230312111448487

image-20230312111504757

image-20230312111518355

题解

思路

解法1思路

其中模拟是根据走迷宫的过程来构建出最佳的一个行进路线,bfs则是对墙进行消除。

流程:

1、根据行进路线规划出最佳的矩阵宽高,并进行填充*。

2、确定出发位置来去模拟走一遍,走的过程中将矩阵四周边上的非墙点填充为空字符并进行扫描入队。

3、使用bfs将所有的空白点来进行消除墙体。

难点:对于想到模拟规划出最佳的矩阵宽度(提前先填充墙体),在利用BFS去消除墙体。

解法1:模拟、BFS

复杂度分析:时间复杂度O(n2);空间复杂度O(n2)

import java.io.BufferedReader;
import java.io.InputStreamReader;public class Main {static final BufferedReader cin = new BufferedReader(new InputStreamReader(System.in));static final int N = 110;static int n;static char[] arr;//确定矩阵的宽、高static int h, w;//定义方向static int[] dx = {0, 1, -1, 0};static int[] dy = {1, 0, 0, -1};//迷宫矩阵static char[][] g = new char[N][N];//墙标记矩阵,false表示不是,true表示是static boolean[][] isWall = new boolean[N][N];//队列static int[] q = new int[N * N];static int hh, tt;//队列头指针(出队)、队尾指针//标记目标点的上下左右都是墙public static void mark (int x, int y) {for (int d = 0; d < 4; d ++) {int xx = x + dx[d];int yy = y + dy[d];if (xx >= 1 && yy >= 1 && xx <= h && yy <= w) {isWall[xx][yy] = true;}}}//将二维点转为一个数字public static int get (int x, int y) {return x * (w + 1) + y;}public static void main(String[] args) throws Exception{n = Integer.parseInt(cin.readLine());arr = cin.readLine().toCharArray();//初始化矩阵(默认都是墙)for (int i = 1; i <= n + 3; i ++) {for (int j = 1; j <= n + 3; j ++) {g[i][j] = '*';}}//确定起始点(u nx-1  d nx+1  l ny-1  r ny+1)int nx = 0, ny = 0;//最大、最小宽高int maxX = 0, maxY = 0, minX = 0, minY = 0;for (int i = 0; i < n; i ++) {if (arr[i] == 'U') nx--;else if (arr[i] == 'L') ny--;else if (arr[i] == 'R') ny++;else nx++;maxX = Math.max(maxX, nx);minX = Math.min(minX, nx);maxY = Math.max(maxY, ny);minY = Math.min(minY, ny);}//确定矩阵大小(3表示最顶部、最底部有一个墙以及是从(1,1)开始的)h = maxX - minX + 3;w = maxY - minY + 3;//确定起始点nx = 2 - minX;ny = 2 - minY;//起点默认是为平地g[nx][ny] = ' ';mark(nx, ny);//开始进行绘制图for (int i = 0; i < n; i ++) {if (arr[i] == 'U') nx--;else if (arr[i] == 'D') nx ++;else if (arr[i] == 'L') ny --;else ny ++;//该地为空地g[nx][ny] = ' ';mark(nx, ny);}//开始从矩阵的最外围开始来进行消除元素for (int i = 1; i <= h; i ++) {for (int j = 1; j <= w; j ++) {//寻找四周非墙的if (isWall[i][j] == false && (i == 1 || j == 1 || i == h || j == w)) {g[i][j] = ' ';q[tt ++] = get(i, j);}}}//bfswhile (hh < tt) {//出队int top = q[hh ++];//确定x、y点int x = top / (w + 1);int y = top % (w + 1);//四个方向for (int d = 0; d < 4; d ++) {int xx = x + dx[d];int yy = y + dy[d];if (xx >= 1 && yy >= 1 && xx <= h && yy <= w && g[xx][yy] =='*' && isWall[xx][yy] == false) {g[xx][yy] = ' ';q[tt ++] = get(xx, yy);}}}//最终去打印整个矩阵for (int i = 1; i <= h; i ++) {for (int j = 1; j <= w; j ++) {System.out.printf("%c", g[i][j]);}System.out.println();}}
}

image-20230312174209044

参考资料

[1]. 蓝桥杯官网真题视频+文字解析

相关内容

热门资讯

bbugreport.exe:... 哎呀,说到这个bbugreport.exe,我的心情真是五味杂陈啊!你懂的,就是那个时不时蹦出来,让...
双网叠加路由器:让网络速度如火... 哎呀,说到这个双网叠加路由器,我简直要跳起来了!你知道吗,自从我换了这款路由器,家里的网络速度简直像...
枭雄怎么重新开始-从失败到新生... 在江湖的沧桑岁月中,每一个枭雄都有过辉煌的巅峰,也有过跌入谷底的苦涩。曾经的我,手握重兵,叱咤风云,...
邮件炸弹攻击主要是什么-警惕!... 邮件炸弹攻击,听起来就像是从科幻电影里跳出来的东西,对吧?但它可是真实存在的,而且就在我们的电子邮箱...
ubuntu 1404关闭3d... 哎呀,说到这个Ubuntu14.04啊,我真的是有点头疼。尤其是那个3D效果,简直是让我眼花缭乱,头...
android操作系统耗电-安... 哎呀,说到安卓手机,我这心里就一肚子火!每次出门前,手机电量还满格,结果没一会儿,就剩下个位数了。这...
雨田蜂蜜:承载童年记忆的甜蜜滋... 在那些细雨蒙蒙的日子里,我总是不由自主地想起家乡的那片雨田,以及那从田间飘来的蜂蜜香。那是一种无法用...
身份证号码查姓名地址,背后隐藏... 嘿,小伙伴们,今天咱们来聊聊一个有点儿神秘的话题——身份证号码查姓名地址。你有没有想过,那些冷冰冰的...
巫师3 dsound.dll在... 哎呀,朋友们,今天咱们来聊聊那个让人抓狂的dsound.dll问题。你知道的,就是那个在《巫师3》里...
android+验证身份证号码... 哎呀,今天咱们来聊聊这个有点严肃但又挺重要的话题——Android手机上怎么验证身份证号码。我知道,...
360数据恢复免费吗-360 ... 大家好,我是一个对电脑一窍不通的小白。前段时间,我不小心删了电脑里的一些重要文件,心里那个急啊,就像...
苹果7使用说明书图解-探索苹果... 大家好呀!今天我要带你们一起探索苹果7的奇妙世界,用最酷炫的方式解锁它的所有秘密!别担心,我们不需要...
win10开机启动项 命令-W... 哎呀,说到Win10开机启动项,我就一肚子火!每次开机,那屏幕就像在跟我玩捉迷藏,转啊转的,半天不见...
相机内存卡文件为空-珍贵照片离... 哎呀,真是气死我了!今天兴冲冲地打开相机,准备回味一下上个周末的欢乐时光,结果一看,我的天,那些珍贵...
苹果手机怎么快速省电-掌握这些... 哎呀呀,说到苹果手机省电,我可是有一肚子的话要说!你知道吗,每次看到手机电量从满格到红线,我的心就像...
北京朝阳医院儿科电话:希望的传... 在北京这座快节奏的都市里,每一个角落都充满了匆忙与喧嚣。但如果你细心倾听,会发现有一个声音始终温暖而...
易购分销平台:海量商品、超实惠... 大家好,我是小张,一个在街角开小店的老板。今天我要给大家聊聊我最近发现的一个超级棒的地方——易购分销...
opensuse 42.2壁纸... 嘿,亲爱的OpenSUSE爱好者们,今天咱们聊聊那些让人眼前一亮的OpenSUSE42.2壁纸!这些...
帝国 政府 模板-在宏伟帝国里... 在这个宏伟的帝国里,每一天都像是政府精心布置的一盘棋。我,一个深陷其中的小卒,感受着这场游戏的起伏与...
苹果恢复大师收费标准揭秘:基本... 大家好,今天咱们来聊聊这个让人又爱又恨的“苹果恢复大师”!你知道吗?这玩意儿简直就是苹果界的救星,但...