题目描述

请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子。如果一条路径经过了矩阵中的某一个格子,则该路径不能再进入该格子。例如下图

矩阵中包含一条字符串"bcced"的路径,但是矩阵中不包含"abcb"路径,因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再次进入该格子。

示例1

输入

 "ABCESFCSADEE",3,4,"ABCCED"

返回值

 true

示例2

输入

 "ABCESFCSADEE",3,4,"ABCB"

返回值

 false

- 解题思路

分析:回溯算法 这是一个可以用回朔法解决的典型题。首先,在矩阵中任选一个格子作为路径的起点。如果路径上的第i个字符不是ch,那么这个格子不可能处在路径上的第i个位置。如果路径上的第i个字符正好是ch,那么往相邻的格子寻找路径上的第i+1个字符。除在矩阵边界上的格子之外,其他格子都有4个相邻的格子。重复这个过程直到路径上的所有字符都在矩阵中找到相应的位置。  由于回朔法的递归特性,路径可以被开成一个栈。当在矩阵中定位了路径中前n个字符的位置之后,在与第n个字符对应的格子的周围都没有找到第n+1个字符,这个时候只要在路径上回到第n-1个字符,重新定位第n个字符。  由于路径不能重复进入矩阵的格子,还需要定义和字符矩阵大小一样的布尔值矩阵,用来标识路径是否已经进入每个格子。当矩阵中坐标为(row,col)的格子和路径字符串中相应的字符一样时,从4个相邻的格子(row,col-1),(row-1,col),(row,col+1)以及(row+1,col)中去定位路径字符串中下一个字符如果4个相邻的格子都没有匹配字符串中下一个的字符,表明当前路径字符串中字符在矩阵中的定位不正确,我们需要回到前一个,然后重新定位。  一直重复这个过程,直到路径字符串上所有字符都在矩阵中找到合适的位置

- Java实现

public class Solution {    private final static int[][] next = {{0, -1}, {0, 1}, {-1, 0}, {1, 0}};    private int rows;    private int cols;    public boolean hasPath(char[] array, int rows, int cols, char[] str) {        if (rows == 0 || cols == 0) return false;        this.rows = rows;        this.cols = cols;        boolean[][] marked = new boolean[rows][cols];        char[][] matrix = buildMatrix(array);        for (int i = 0; i < rows; i++)            for (int j = 0; j < cols; j++)                if (backtracking(matrix, str, marked, 0, i, j))                    return true;        return false;    }    private boolean backtracking(char[][] matrix, char[] str,                                 boolean[][] marked, int pathLen, int r, int c) {        if (pathLen == str.length) return true;        if (r < 0 || r >= rows || c < 0 || c >= cols                || matrix[r][c] != str[pathLen] || marked[r][c]) {            return false;        }        marked[r][c] = true;        for (int[] n : next)            if (backtracking(matrix, str, marked, pathLen + 1, r + n[0], c + n[1]))                return true;        marked[r][c] = false;        return false;    }    private char[][] buildMatrix(char[] array) {        char[][] matrix = new char[rows][cols];        for (int r = 0, idx = 0; r < rows; r++)            for (int c = 0; c < cols; c++)                matrix[r][c] = array[idx++];        return matrix;    }}

矩阵每一行重复_【剑指offer】65 矩阵中的路径相关推荐

  1. 找第一个只出现一次的字符_剑指offer 字符流中第一个只出现一次的字符

    题目描述: 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是'g'.当从该字符流中读出前六个字" ...

  2. leetcode 打印_剑指 Offer 总结 - leetcode 剑指offer系列

    剑指 Offer 系列完结撒花!! 本篇文章是对整个系列的精华总结, 对系列的每篇文章进行了分类, 并用一句话概括每道题的思路, 方便大家理解和记忆, 当然也包含原文完整链接供大家参考 总的来说, 写 ...

  3. 字符串全排列算法_C#版_剑指OFFER

    字符串全排列算法_C#版_剑指OFFER 题目描述 ​题目描述 输入一个长度为 n 字符串,打印出该字符串中字符的所有排列,你可以以任意顺序返回这个字符串数组. 例如输入字符串ABC,则输出由字符A, ...

  4. java中数组的下标比较_【Java】 剑指offer(53-3) 数组中数值和下标相等的元素

    本文参考自<剑指offer>一书,代码采用Java语言. 题目 假设一个单调递增的数组里的每个元素都是整数并且是唯一的.请编程实现一个函数找出数组中任意一个数值等于其下标的元素.例如,在数 ...

  5. java 加法不用_【Java】 剑指offer(65) 不用加减乘除做加法

    本文参考自<剑指offer>一书,代码采用Java语言. 题目 写一个函数,求两个整数之和,要求在函数体内不得使用+.-.×.÷四则运算符号. 思路 对数字做运算,除了四则运算外,只剩下位 ...

  6. 【算法】剑指 Offer 12. 矩阵中的路径

    文章目录 1.概述 2.我的算法 2.1 棋盘 2.1 开始节点 2.2 点没被访问 2.3 点是否在棋盘内 2.4 下一步 2.5 主方法 2.6 核心方法 2.7 测试类 3.leecode1 1 ...

  7. 【LeetCode】剑指 Offer 61. 扑克牌中的顺子

    [LeetCode]剑指 Offer 61. 扑克牌中的顺子 文章目录 [LeetCode]剑指 Offer 61. 扑克牌中的顺子 一.集合Set + 遍历 二.排序 + 遍历 总结 解题思路 根据 ...

  8. 剑指 Offer 65. 不用加减乘除做加法(位运算、递归、迭代)

    一.题目 剑指 Offer 65. 不用加减乘除做加法 题目描述 写一个函数,求两个整数之和,要求在函数体内不得使用 "+"."-"."*" ...

  9. 【每日一题】剑指 Offer 22. 链表中倒数第k个节点

    剑指 Offer 22. 链表中倒数第k个节点

  10. 【LeetCode】剑指 Offer 51. 数组中的逆序对

    [LeetCode]剑指 Offer 51. 数组中的逆序对 文章目录 [LeetCode]剑指 Offer 51. 数组中的逆序对 package offer;public class Soluti ...

最新文章

  1. 智能会议白板系统每日开发记录
  2. 【我的Android进阶之旅】推荐一款能提升数十倍效率的Android应用开发助手
  3. 全网最简单的dubbo源码调试,建议点赞收藏!!!
  4. django orm级联_第 03 篇:创建 Django 博客的数据库模型
  5. 中国的TD-LTE-Advanced被国际电联确立为4G标准!
  6. 【浙大网新图灵通讯】无废话简单高效C#编码规范20100611
  7. Java 学习笔记 反射与迭代器
  8. 快速入门SSM整合配置建立第一个SSM项目模板
  9. flutter PositionedTransition 实现缩放动画
  10. Git学习总结(12)——多人开发 Git 分支管理详解
  11. mysql日期函数大全_MYSQL教程mysql日期时间函数大全 mysql函数大全
  12. 友勤发布2019年Oracle P6软件培训公开课计划
  13. 查看MySQL数据库占用空间大小
  14. word当前页面设置第一页
  15. JavaSE----基础语法(数组)
  16. qcqa是什么职位_QA和QC是什么意思?区别是什么?
  17. 共享储物柜app开发方案
  18. 榆熙电商:拼多多商家怎样开通电子面单服务?有何优势?
  19. SOLIDWORKS: Visualize SOLIDWORKS:可视化 Lynda课程中文字幕
  20. Unity3D 自动切割动画

热门文章

  1. JAVA日期和时间API
  2. Java多线程系列--“JUC锁”05之 非公平锁
  3. jmeter校验结果_Jenkins在实际失败时验证JMeter构建是否成功
  4. 【OS学习笔记】二十七 保护模式八:任务切换的方法之----jmp与call的区别以及任务的中断嵌套
  5. 自定义链表增,删除,链表逆序
  6. thymeleaf 模板语言简介
  7. ubuntu14.04 upgrade出现【Ubuntu is running in low-graphics mode】问题的一个解决办法
  8. Oracle 客户端连接服务器[转]
  9. 【翻译】使用Ext JS设计响应式应用程序
  10. WinForm中使用WPF的控件