原题链接:蓝桥杯2015年第六届真题-穿越雷区
我在做笔记!!!
理解的属于前面大佬们的代码
思路:
1、找到A点的坐标,标记下来,储存4四种走法类型,申请一个boolean类型,判段方格是否走过,避免死循环
2、循环4种类型,判段是否超出边界,如果没有超出边界,标记为true,继续DFS下一个坐标,回溯
3、如果找到了B点,判段当前count步数与ans中储存的最小步数谁更小,储存更小的
4、如果没有找到,ans即为原设定值,返回-1,找到了返回ans
DFS类型基本思路
1、初始点出发
2、遍历每种情况,标记当前点为true
3、回溯
4、判段终点
注意事项:
参考代码:
import java.io.*; public class Main { static BufferedReader bf=new BufferedReader(new InputStreamReader(System.in)); static PrintWriter pw=new PrintWriter(new BufferedWriter(new OutputStreamWriter(System.out))); //记录A坐标 static int a,b; //储存行走方向的数组 static int dir[][] = {{1,0},{0,1},{-1,0},{0,-1}}; static int ans=10000; //最小步数 //题目最大给出范围100 static char[][] maze=new char[101][101]; static boolean[][] iswalked=new boolean[101][101]; static int n; public static void main(String[] args) throws NumberFormatException, IOException { n=Integer.parseInt(bf.readLine());//方阵大小 for(int i=0;i<n;i++) { String[] temp=bf.readLine().split(" "); for(int j=0;j<n;j++) { maze[i][j]=temp[j].charAt(0); if(maze[i][j]=='A') { a=i; b=j; } } } dfs(a,b,'A',0); if(ans!=10000) { pw.print(ans); }else { //走不到 pw.print("-1"); } pw.flush(); } public static void dfs(int x,int y,char laststatus,int count) { if(maze[x][y]=='B') { ans=Math.min(ans, count); return; } //遍历上下左右四种情况 for(int i=0;i<4;i++) { int tempx=x+dir[i][0]; int tempy=y+dir[i][1]; if(tempx>=0&&tempy>=0&&tempx<n&&tempy<n&&maze[x][y]!=maze[tempx][tempy]&&!iswalked[tempx][tempy]) { iswalked[tempx][tempy]=true; dfs(tempx,tempy,laststatus,count+1); //回溯 iswalked[tempx][tempy]=false; } } } }
0.0分
1 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复