深度优先算法DFS
英雄要从H点出发,去解救位于M点的美女。
迷宫的围墙用#表示,带*号的位置表示有杀手埋伏,这些点都是不能走的,
那么英雄要最少走多少步才能解救美女呢?
- package myalgorithm;
- import java.util.Arrays;
- import java.util.LinkedList;
- import java.util.Queue;
- public class ShortPath {
- /*全局最短路径*/
- public int stepnum = 999;
- /*构建11*11的迷宫,英雄H在(1,1)的位置出发,去解救美女M(6,8)*/
- char[][] graph = {
- {'#','#','#','#','#','#','#','#','#','#','#'},
- {'#','H','_','_','*','_','_','*','_','_','#'},
- {'#','_','_','_','_','_','_','_','_','_','#'},
- {'#','_','*','_','_','_','*','_','_','_','#'},
- {'#','_','_','_','*','_','_','_','_','*','#'},
- {'#','_','_','_','_','_','_','*','_','*','#'},
- {'#','_','*','_','_','_','_','_','M','_','#'},
- {'#','*','_','_','*','_','_','_','_','_','#'},
- {'#','_','_','_','_','_','_','_','_','_','#'},
- {'#','_','_','_','*','_','_','_','_','_','#'},
- {'#','#','#','#','#','#','#','#','#','#','#'},
- };
- /*初始标记数组都为0*/
- public int[][] mark = new int[graph.length][graph.length];
- /*每一个位置有四种选择:右下左上*/
- public int[][] choose = {
- {0,1},
- {1,0},
- {0,-1},
- {-1,0}
- };
- /*采用递归的DFS算法*/
- public void DFS(int x,int y, int step) {
- /*找到美女M*/
- if (graph[x][y] == 'M')
- {
- if(step < stepnum)
- {
- stepnum = step;
- }
- return;//找到之后立即返回,不再继续
- }
- //新位置
- int tx = 0;
- int ty = 0;
- for(int i=0;i<4;i++)
- {
- tx = x + choose[i][0];
- ty = y + choose[i][1];
- if(graph[tx][ty] != '#'
- && graph[tx][ty] != '*'
- && mark[tx][ty] == 0)
- {
- mark[tx][ty] = 1;//标记该点已经走过
- DFS(tx,ty,step+1);
- mark[tx][ty] = 0;//取消该点的标记
- }
- }
- return;
- }
- public static void main(String[] args) {
- ShortPath my = new ShortPath();long start1 = System.currentTimeMillis();
- my.mark[1][1] = 1;
- my.DFS(1,1,0);long end1 = System.currentTimeMillis();
- System.out.println("DFS step: " + my.stepnum + " time:" + (end1-start1));
- }
- }
非常耗时:DFS step: 12 time:109830
深度优先算法DFS的更多相关文章
- 广度优先算法(BFS)与深度优先算法(DFS)
一.广度优先算法BFS(Breadth First Search) 基本实现思想 (1)顶点v入队列. (2)当队列非空时则继续执行,否则算法结束. (3)出队列取得队头顶点v: (4)查找顶点v的所 ...
- [ACM训练] 算法初级 之 搜索算法 之 深度优先算法DFS (POJ 2251+2488+3083+3009+1321)
对于深度优先算法,第一个直观的想法是只要是要求输出最短情况的详细步骤的题目基本上都要使用深度优先来解决.比较常见的题目类型比如寻路等,可以结合相关的经典算法进行分析. 常用步骤: 第一道题目:Dung ...
- 图的遍历(搜索)算法(深度优先算法DFS和广度优先算法BFS)
图的遍历的定义: 从图的某个顶点出发访问遍图中所有顶点,且每个顶点仅被访问一次.(连通图与非连通图) 深度优先遍历(DFS): 1.访问指定的起始顶点: 2.若当前访问的顶点的邻接顶点有未被访问的,则 ...
- 图的深度优先搜索(DFS)和广度优先搜索(BFS)算法
深度优先(DFS) 深度优先遍历,从初始访问结点出发,我们知道初始访问结点可能有多个邻接结点,深度优先遍历的策略就是首先访问第一个邻接结点,然后再以这个被访问的邻接结点作为初始结点,访问它的第一个邻接 ...
- 【算法入门】深度优先搜索(DFS)
深度优先搜索(DFS) [算法入门] 1.前言深度优先搜索(缩写DFS)有点类似广度优先搜索,也是对一个连通图进行遍历的算法.它的思想是从一个顶点V0开始,沿着一条路一直走到底,如果发现不能到达目标解 ...
- Java与算法之(5) - 老鼠走迷宫(深度优先算法)
小老鼠走进了格子迷宫,如何能绕过猫并以最短的路线吃到奶酪呢? 注意只能上下左右移动,不能斜着移动. 在解决迷宫问题上,深度优先算法的思路是沿着一条路一直走,遇到障碍或走出边界再返回尝试别的路径. 首先 ...
- 图的深度优先遍历(DFS)和广度优先遍历(BFS)
body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...
- 广度优先遍历-BFS、深度优先遍历-DFS
广度优先遍历-BFS 广度优先遍历类似与二叉树的层序遍历算法,它的基本思想是:首先访问起始顶点v,接着由v出发,依次访问v的各个未访问的顶点w1 w2 w3....wn,然后再依次访问w1 w2 w3 ...
- 在图中寻找最短路径-----深度优先算法C++实现
求从图中的任意一点(起点)到另一点(终点)的最短路径,最短距离: 图中有数字的点表示为图中的不同海拔的高地,不能通过:没有数字的点表示海拔为0,为平地可以通过: 这个是典型的求图中两点的最短路径:本例 ...
随机推荐
- 深入探讨this指针
深入探讨this指针 为了写这篇文章,准备了好长时间,翻遍了箱底的书籍.可是如今还是不敢放开手来写,战战兢兢.不是操心自己写错,而是唯恐自己错误误导别人.同一时候也希望这篇文章能给你一点收获.既然 ...
- php 下载远程图片 的几种方法(转)
1.获取远程文件大小及信息的函数 function getFileSize($url){ $url = parse_url($url); if($fp = @fso ...
- 理解php Hash函数,增强密码安全
1.声明 密码学是一个复杂的话题,我也不是这方面的专家.许多高校和研究机构在这方面都有长期的研究.在这篇文章里,我希望尽量使用简单易懂的方式向你展示一种安全存储Web程序密码的方法. 2.“Hash” ...
- php运行步骤解析
2000年, PHP4.0发布的时候,引入了Zend Engine. Zend引擎把PHP代码的执行切分成两个阶段: 一. Zend Engine 解析PHP代码并生成二进制中间码Zend Opcod ...
- Redis 列表(List)
Redis列表是简单的字符串列表,按照插入顺序排序.你可以添加一个元素导列表的头部(左边)或者尾部(右边) 一个列表最多可以包含 232 - 1 个元素 (4294967295, 每个列表超过40亿个 ...
- 利用 Composer 一步一步构建自己的 PHP 框架(一)——基础准备
『Composer 一统天下的时代已经到来!』——白岩松 “一个时代结束了,另一个时代开始了.” Framework Interoperability Group(框架可互用性小组),简称 FIG,成 ...
- 使用JS制作一个鼠标可拖的DIV(三)——移动带图片DIV
当DIV元素里,存在图片元素的时候,会使拖动出现异常. 因为图片元素本身就支持拖动,所以,只要在图片标签加入:draggable='false'. 如下: <div onmousedown=&q ...
- 关于直接创建视图UITableViewController显示(初学)
今天渣渣想直接创建一个UITableView视图作为根视图来用结果发现有警告,才明白TableView和view是不能直接作为根视图的,需要放在ViewController上.做个笔记详细了解下. 参 ...
- C语言有关数组的几点
动态大小数组 先来看一段代码: ; int a[n]; int i; ;i<n;i++) { a[i]=i; printf("%d\n",a[i]); } 我在声明数组a时, ...
- Oracle常用命令13(数据库的启动、关闭)
数据库的启动.关闭 数据库的启动:安装启动.非安装启动.共享启动.独占启动.约束启动.强制启动 --不登陆的方式进入 Sqlplus /nolog 安装启动: Startup {pfile=<f ...