2021-05-26:给定一个char[][] matrix,也就是char类型的二维数组,再给定一个字符串word,可以从任何一个某个位置出发,可以走上下左右,能不能找到word?char[][] m = {{ ‘a’, ‘b’, ‘z’ }, { ‘c’, ‘d’, ‘o’ }, { ‘f’, ‘e’, ‘o’ }}。设定1:可以走重复路的情况下,返回能不能找到。比如,word = “zoooz”,是可以找到的,z -> o -> o -> o -> z,因为允许走一条路径中已经走过的字符。设定2:不可以走重复路的情况下,返回能不能找到。比如,word = “zoooz”,是不可以找到的,因为允许走一条路径中已经走过的字符不能重复走。

福大大 答案2021-05-26:

自然智慧即可。
递归。对于不可重复的情况,进入递归,走过的位置需要标记为0;退出递归,走过的位置需要恢复成原来的值。

代码用golang编写。代码如下:

package main

import "fmt"

func main() {
m := [][]byte{
{'a', 'b', 'z'},
{'c', 'd', 'o'},
{'f', 'e', 'o'}}
word1 := "zoooz"
word2 := "zoo"
if true {
fmt.Println("可重复--------")
ret1 := findWord1(m, word1)
ret2 := findWord1(m, word2)
fmt.Println(ret1)
fmt.Println(ret2)
}
if true {
fmt.Println("不重复--------")
ret1 := findWord2(m, word1)
ret2 := findWord2(m, word2)
fmt.Println(ret1)
fmt.Println(ret2)
}
} // 可以走重复的设定
func findWord1(m [][]byte, word string) bool {
if word == "" {
return true
}
if len(m) == 0 || len(m[0]) == 0 {
return false
}
N := len(m)
M := len(m[0])
wlen := len(word)
// dp[i][j][k]表示:必须以m[i][j]这个字符结尾的情况下,能不能找到w[0...k]这个前缀串
dp := make([][][]bool, N)
for i := 0; i < N; i++ {
dp[i] = make([][]bool, M)
for j := 0; j < M; j++ {
dp[i][j] = make([]bool, wlen)
}
}
for i := 0; i < N; i++ {
for j := 0; j < M; j++ {
dp[i][j][0] = m[i][j] == word[0]
}
}
for k := 1; k < wlen; k++ {
for i := 0; i < N; i++ {
for j := 0; j < M; j++ {
dp[i][j][k] = m[i][j] == word[k] && checkPrevious(dp, i, j, k)
}
}
}
for i := 0; i < N; i++ {
for j := 0; j < M; j++ {
if dp[i][j][wlen-1] {
return true
}
}
}
return false
} func checkPrevious(dp [][][]bool, i int, j int, k int) bool {
up := false
down := false
left := false
right := false
if i > 0 {
up = dp[i-1][j][k-1]
}
if i < len(dp)-1 {
down = dp[i+1][j][k-1]
}
if j > 0 {
left = dp[i][j-1][k-1]
}
if j < len(dp[0])-1 {
right = dp[i][j+1][k-1]
}
return up || down || left || right
} // 不可以走重复路的设定
func findWord2(m [][]byte, word string) bool {
if word == "" {
return true
}
if len(m) == 0 || len(m[0]) == 0 {
return false
} for i := 0; i < len(m); i++ {
for j := 0; j < len(m[0]); j++ {
if process(m, i, j, word, 0) {
return true
}
}
}
return false
} // 从m[i][j]这个字符出发,能不能找到w[k...]这个后缀串
func process(m [][]byte, i int, j int, str string, k int) bool {
if k == len(str) {
return true
}
if i == -1 || i == len(m) || j == -1 || j == len(m[0]) || m[i][j] == 0 || m[i][j] != str[k] {
return false
}
m[i][j] = 0
ans := false
if process(m, i+1, j, str, k+1) || process(m, i-1, j, str, k+1) || process(m, i, j+1, str, k+1) || process(m, i, j-1, str, k+1) {
ans = true
}
m[i][j] = str[k]
return ans
}

执行结果如下:


左神java代码

2021-05-26:给定一个char[][] matrix的更多相关文章

  1. 给定一个字符串,把字符串内的字母转换成该字母的下一个字母,a换成b,z换成a,Z换成A,如aBf转换成bCg, 字符串内的其他字符不改变,给定函数,编写函数 void Stringchang(const char*input,char*output)其中input是输入字符串,output是输出字符串

    import java.util.Scanner; /*** * 1. 给定一个字符串,把字符串内的字母转换成该字母的下一个字母,a换成b,z换成a,Z换成A,如aBf转换成bCg, 字符串内的其他字 ...

  2. JAVA 之 每日一记 之 算法( 给定一个正整数,返回它在 Excel 表中相对应的列名称。 )

    题目: 给定一个正整数,返回它在 Excel 表中相对应的列名称. 例如: 1 -> A 2 -> B 3 -> C ... 26 -> Z 27 -> AA 28 -& ...

  3. 2021.05.03 T3 数字

    2021.05.03 T3 数字 问题描述 一个数字被称为好数字当他满足下列条件: 1. 它有**2*n**个数位,n是正整数(允许有前导0) 2. 构成它的每个数字都在给定的数字集合S中. 3. 它 ...

  4. 2021.07.26 P1022 计算器的改良(字符串)

    2021.07.26 P1022 计算器的改良(字符串) 改进: 如果是我出题,我一定把未知数设为ab.buh.bluesky之类的长度不只是1的字符串! 题意: 一个一元一次方程,求解. 分析: 1 ...

  5. 任意给定一个正整数N,求一个最小的正整数M(M>1),使得N*M的十进制表示形式里只含有1和0。

    题目:任意给定一个正整数N,求一个最小的正整数M(M>1),使得N*M的十进制表示形式里只含有1和0. 解法一:暴力求解.从1开始查找M,然后判断M*N=X这个数字是否只含有0,1. 解法二:由 ...

  6. 面试题:给定一个长度为N的数组,其中每个元素的取值范围都是1到N。判断数组中是否有重复的数字

    题目:给定一个长度为N的数组,其中每个元素的取值范围都是1到N.判断数组中是否有重复的数字.(原数组不必保留) 方法1.对数组进行排序(快速,堆),然后比较相邻的元素是否相同.时间复杂度为O(nlog ...

  7. 给定一个字符串里面只有"R" "G" "B" 三个字符,请排序,最终结果的顺序是R在前 G中 B在后。 要求:空间复杂度是O(1),且只能遍历一次字符串。

    题目:给定一个字符串里面只有"R" "G" "B" 三个字符,请排序,最终结果的顺序是R在前 G中 B在后. 要求:空间复杂度是O(1),且 ...

  8. 给定一个十进制数,将其转化为N进制数-----17年滴滴笔试题

    题目:给定一个十进制数M,将其转化为N进制数,其中2<=N<=16,其中N为32为整型数; 输入:M N,如7 2 输出转化结果:111 注意点:考虑负数的情况,记得添加负号(其实直接添加 ...

  9. 给定一个公式字符串用java进行拆解并计算结果

    需求很简单,给定一个字符串形式的公式规则,用java代码进行拆解,并能计算出结果. ♦考虑字符串中数字格式[整数.小数点] ♦考虑字符串中运算符[+-*/()] ♦考虑空格.运算规则[被0除] 以下是 ...

  10. 旋转图像 给定一个 n × n 的二维矩阵表示一个图像。

    给定一个 n × n 的二维矩阵表示一个图像. 将图像顺时针旋转 90 度. 说明: 你必须在原地旋转图像,这意味着你需要直接修改输入的二维矩阵.请不要使用另一个矩阵来旋转图像. 示例 : 给定 ma ...

随机推荐

  1. (转载)Python 浅析线程(threading模块)和进程(process)

    线程是操作系统能够进行运算调度的最小单位.它被包含在进程之中,是进程中的实际运作单位.一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程,每条线程并行执行不同的任务 进程与线程 什么 ...

  2. BaseMapperX

    package cn.iocoder.yudao.framework.mybatis.core.mapper; import cn.iocoder.yudao.framework.common.poj ...

  3. 中国科学院2019年大学生数学夏令营考试试题 选做 (Mathematica练习)

    目录 试题 1 6 9 solution to (1) solution to (2) 相关读物 试题 选择性地做一些,没有对答案.能机器算的我就不拿纸笔算了,当然实际考试是笔试... 不定期更新 1 ...

  4. 接入HMS Core应用内支付服务过程中一些常见问题总结

    华为HMS Core应用内支付服务(In-App Purchases,IAP)为应用提供便捷的应用内支付体验和简便的接入流程.该服务支持客户端和服务端两种开发形式,具体可以参考官方文档. 往期文章:常 ...

  5. 从源码彻底理解 Prometheus/VictoriaMetrics 中的 relabel_configs/metric_relabel_configs 配置

    背景 最近接手维护了公司的指标监控系统,之后踩到坑就没站起来过.. 本次问题的起因是我们配置了一些指标的删除策略没有生效: - action: drop_metrics regex: "^e ...

  6. 最大流应用(Maximum Flow Application)

    1. 二分图匹配(Bipartite Matching) 1.1 匹配(Matching) Def. Given an undirected graph \(G = (V, E)\), subset ...

  7. 在Vue3+TypeScript 前端项目中使用事件总线Mitt

    事件总线Mitt使用非常简单,本篇随笔介绍在Vue3+TypeScript 前端项目中使用的一些场景和思路.我们在Vue 的项目中,经常会通过emits 触发事件来通知组件或者页面进行相应的处理,不过 ...

  8. 详解DDD:如何避免写流水账代码?

    在日常工作中我观察到,面对老系统重构和迁移场景,有大量代码属于流水账代码,通常能看到开发在对外的API接口里直接写业务逻辑代码,或者在一个服务里大量的堆接口,导致业务逻辑实际无法收敛,接口复用性比较差 ...

  9. PHP 微信三方平台代公众号发起网页授权 获取用户信息

    1.获取code 2.通过授权回调地址的code获取用户access_token和open_id 3.通过access_token和open_id 获取用户基本信息 class wx_user { p ...

  10. 五月十三号Java基础知识点

    1.getFields()和getMethods()方法获得权限为public的本类的以及父类继承的成员变量和成员方法2.getDeclaredFields()和getDeclaredMethods( ...