博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
剑指offer——矩阵中的路径
阅读量:4108 次
发布时间:2019-05-25

本文共 925 字,大约阅读时间需要 3 分钟。

import java.util.*;public class Solution {    public boolean hasPath (char[][] matrix, String word) {//         循环多次找到首个字母的初始位置        for(int i=0;i
=matrix.length||n>=matrix[0].length||vis[m][n]==true)return false;// 如果这个位置字母和字符串尾字母一样,且字符串序号就是最后一个,代表遍历完了,返回true,不在遍历 if(word.charAt(word.length()-1)==matrix[m][n]&&(k==word.length()-1))return true;// 字符串字母是序号对应字母 if(word.charAt(k)==matrix[m][n]){// 访问过了 vis[m][n]=true;// 如果上下左右有下一个字母(k+1)则继续遍历,否则访问设置为未访问(每个字母这能经过一次,没有找到下一个字母,所以其实没有访问过) if(dfs(m+1,n,vis,matrix,k+1,word)||dfs(m,n+1,vis,matrix,k+1,word)||dfs(m,n-1,vis,matrix,k+1,word)||dfs(m-1,n,vis,matrix,k+1,word)){ return true; }else{ vis[m][n]=false; return false; } }else{ //当前不是对应字母,返回false vis[m][n]=false; return false; } }}

 

转载地址:http://mwssi.baihongyu.com/

你可能感兴趣的文章
Merge Two Sorted Lists 合并两个有序链表
查看>>
pow(x,n) 为什么错这么多次
查看>>
Jump Game 动态规划
查看>>
Binary Tree Maximum Path Sum 自底向上求解(重重重重)
查看>>
Subsets 深搜
查看>>
Subsets II
查看>>
Edit Distance 字符串距离(重重)
查看>>
Gray Code 格雷码
查看>>
对话周鸿袆:从程序员创业谈起
查看>>
Node.js入门之神秘的服务器端JavaScript
查看>>
Node.js初探之与Mysql的交互
查看>>
web.py 0.3 新手指南 - 如何用Gmail发送邮件
查看>>
web.py 0.3 新手指南 - 实时语言切换
查看>>
web.py 0.3 新手指南 - RESTful doctesting using app.request
查看>>
web.py 0.3 新手指南 - 使用db.query进行高级数据库查询
查看>>
web.py 0.3 新手指南 - 多数据库使用
查看>>
一步步开发 Spring MVC 应用
查看>>
python: extend (扩展) 与 append (追加) 的差别
查看>>
「译」在 python 中,如果 x 是 list,为什么 x += "ha" 可以运行,而 x = x + "ha" 却抛出异常呢?...
查看>>
谷歌阅读器将于2013年7月1日停止服务,博客订阅转移到邮箱
查看>>