问题描述

请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径。路径可以从矩阵中的任意一格开始,每一步可以在矩阵中向左、右、上、下移动一格。如果一条路径经过了矩阵的某一格,那么该路径不能再次进入该格子。例如,在下面的3×4的矩阵中包含一条字符串“bfce”的路径(路径中的字母用加粗标出)。

[["a","b","c","e"],
["s","f","c","s"],
["a","d","e","e"]] 但矩阵中不包含字符串“abfb”的路径,因为字符串的第一个字符b占据了矩阵中的第一行第二个格子之后,路径不能再次进入这个格子。 示例 1: 输入:board = [["A","B","C","E"],["S","F","C","S"],["A","D","E","E"]], word = "ABCCED"
输出:true
示例 2: 输入:board = [["a","b"],["c","d"]], word = "abcd"
输出:false
提示: 1 <= board.length <= 200
1 <= board[i].length <= 200

代码

使用额外空间:

class Solution {
public:
bool exist(vector<vector<char>>& board, string word) {
int length = word.size();
int m = board.size(),n = board[0].size();
vector<vector<bool>> flag(m,vector<bool>(n,false));
for(int i = 0; i < m; ++i)
{
for(int j = 0; j < n; ++j)
if( check(board,i,j,word,0,flag))
return true;;
}
return false;
}
bool check(vector<vector<char>>& board, int indx,int indy,string word,int ind,vector<vector<bool>> &flag)
{
if(ind == word.size())return true;
int m = board.size(),n = board[0].size();
if(indx < 0 || indx >= m || indy < 0 || indy >= n || board[indx][indy]!=word[ind]||flag[indx][indy])
return false;
flag[indx][indy] = true;
bool res = check(board,indx+1,indy,word,ind+1,flag)||
check(board,indx,indy+1,word,ind+1,flag)||
check(board,indx-1,indy,word,ind+1,flag)||
check(board,indx,indy-1,word,ind+1,flag);
flag[indx][indy] = false;
return res;
}
};

结果:

执行用时 :448 ms, 在所有 C++ 提交中击败了14.88%的用户
内存消耗 :187.6 MB, 在所有 C++ 提交中击败了100.00%的用户

代码

不使用额外空间

class Solution {
public:
bool exist(vector<vector<char>>& board, string word) {
int length = word.size();
int m = board.size(),n = board[0].size();
for(int i = 0; i < m; ++i)
{
for(int j = 0; j < n; ++j)
if( check(board,i,j,word,0))
return true;;
}
return false;
}
bool check(vector<vector<char>>& board, int indx,int indy,string word,int ind)
{
if(ind == word.size())return true;
int m = board.size(),n = board[0].size();
if(indx < 0 || indx >= m || indy < 0 || indy >= n || board[indx][indy]!=word[ind]||board[indx][indy]=='*')
return false;
char c = board[indx][indy];
board[indx][indy]='*';
bool res = check(board,indx+1,indy,word,ind+1)||
check(board,indx,indy+1,word,ind+1)||
check(board,indx-1,indy,word,ind+1)||
check(board,indx,indy-1,word,ind+1);
board[indx][indy] = c;
return res;
}
};

结果:

执行用时 :392 ms, 在所有 C++ 提交中击败了24.83%的用户
内存消耗 :187 MB, 在所有 C++ 提交中击败了100.00%的用户

《剑指offer》面试题12. 矩阵中的路径的更多相关文章

  1. 剑指offer(65)矩阵中的路径

    题目描述 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径.路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子.如果一条路径经过了矩阵中 ...

  2. 【剑指Offer】65、矩阵中的路径

      题目描述:   请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径.路径可以从矩阵中的任意一个格子开始,每一步可以在矩阵中向左,向右,向上,向下移动一个格子.如果一条路径经 ...

  3. 剑指Offer:面试题15——链表中倒数第k个结点(java实现)

    问题描述 输入一个链表,输出该链表中倒数第k个结点.(尾结点是倒数第一个) 结点定义如下: public class ListNode { int val; ListNode next = null; ...

  4. 【剑指Offer】面试题12. 矩阵中的路径

    题目 请设计一个函数,用来判断在一个矩阵中是否存在一条包含某字符串所有字符的路径.路径可以从矩阵中的任意一格开始,每一步可以在矩阵中向左.右.上.下移动一格.如果一条路径经过了矩阵的某一格,那么该路径 ...

  5. 剑指Offer:面试题29——数组中出现次数超过一半的数字(java实现)

    PS:在前几天的面试中,被问到了这个题.然而当时只能用最低效的方法来解. 问题描述: 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字.例如输入一个长度为9的数组{1,2,3,2,2,2, ...

  6. 剑指offer 面试题 删除链表中重复的节点

    题目描述 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针. 例如,链表1->2->3->3->4->4->5 处理后 ...

  7. 剑指Offer:面试题12——打印1到最大的n位数(java实现)

    问题描述: 输入数字n,按顺序打印出从1到最大的n位十进制数,比如输入3,则打印出1,2,3一直到最大的3位数即999. 思路1:最简单的想法就是先找出最大的n位数,然后循环打印即可. public ...

  8. 【剑指offer 面试题12】打印1到最大的n位数

    思路: 用n位字符数组表示n位数,通过递归的方式逐层(位)遍历,递归终止时打印. #include "stdio.h" #include "string.h" ...

  9. 剑指offer 面试题56. 数组中只出现一次的两个数字

    题目描述 一个整型数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字. 方法1:用set记录出现过的数字 class Solution { public: void F ...

随机推荐

  1. 搭建ELK日志平台(单机)

    系统版本:Ubuntu 16.04.7 LTS 软件架构:Filebeat+Kafka+Logstash+Elasticsearch+Kibana+Nginx 软件版本:Filebeat-7.16.0 ...

  2. mysql使用自定义序列实现row_number功能

    看了一些文章,终于知道该怎么在 mysql 里面实现 row_number() 排序 话不多说,show you the code: 第一步:建表: create table grades( `nam ...

  3. Django modules模块

    http://www.cnblogs.com/wupeiqi/articles/5246483.html

  4. java 、abstract修饰的【抽象类】【比如几何图形类】

    现实中问题引入 现实中一类具有共同特征的类,但是无法具体实现.,比如我们定义了一个几何类,叫做Shape,我们有一个方法要计算周长,直接在每个子类实现虽然可以,但是无法通过Shape定义的实例来访问到 ...

  5. mysql联合查询更新数据库例子

    mysql联合查询更新数据库例子,用户表,部门表,把用户表中的部门属性更新为部门表的主键UPDATE user_table AS utINNER JOIN belongdept AS bd ON bd ...

  6. textarea控件好奇怪啊,用<s:if>标签居然不在一行回出现很多的空格,奇葩啊

    textarea控件好奇怪啊,用<s:if>标签居然不在一行回出现很多的空格,奇葩啊

  7. 当页面是本地页面时,通过ajax访问tomcat里的action,传递的参数在action里并不能识别

    当页面是本地页面时,通过ajax访问tomcat里的action,传递的参数在action里并不能识别,这个问题困扰了我不少时间. 在测试时发现此问题

  8. SpringBoot 整合MinIO

    引入依赖 <dependency> <groupId>io.minio</groupId> <artifactId>minio</artifact ...

  9. 基于CA认证(结合文档在线预览)的电子签章解决方案

    分享一个基于CA认证(结合文档在线预览)的电子签章实现思路,恰巧是最近项目中遇到的,欢迎大家一起讨论. 一. 项目背景 在公司业务系统中,按照传统的签章方式,存在以下痛点: 1.成本高,体现在纸质合同 ...

  10. FreeSql.Provider.SqliteCore如何加密

    FreeSql.Provider.SqliteCore 是FreeSql基于微软提供的最新的Microsoft.Data.Sqlite.Core驱动的实现. 支持的版本 .NETStandard2.0 ...