题解 | #最小的K个数#

矩阵中的路径

http://www.nowcoder.com/practice/2a49359695a544b8939c77358d29b7e6

用回溯法(DFS 深度搜索)做:
记得要用一种方式标注已被访问的位置,若在此点找不到路径,要记得把访问状态改回去!!!
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param matrix char字符型二维数组 
# @param word string字符串 
# @return bool布尔型
#

def dfs(matrix,word,i,j,m,n,dirs):
            if not word:
                return True
            if i<0&nbs***bsp;i>=m&nbs***bsp;j<0&nbs***bsp;j>=n&nbs***bsp;matrix[i][j]!=word[0]&nbs***bsp;matrix[i][j]=="0":
                return False
            
            tmp=matrix[i][j]
            matrix[i][j]="0"
            
            for k in range(4):
                if dfs(matrix, word[1:], i+dirs[k][0], j+dirs[k][1], m, n, dirs):
                    return True
            
            matrix[i][j]=tmp
            
            
class Solution:
    def hasPath(self , matrix , word ):

        dirs=[[0,-1],[0,1],[-1,0],[1,0]]
        m=len(matrix)
        n=len(matrix[0])
        for i in range(m):
            for j in range(n):
                if dfs(matrix,word,i,j,m,n,dirs):
                    return True
        return False
        
        
        # write code here


全部评论

相关推荐

不愿透露姓名的神秘牛友
2024-12-30 18:02
程序员牛肉:1.可以标记一下自己的学校是985,有一些hr可能没想到你这个院校是985的。 2.简历所呈现出来的能力还是有点差的,苍穹外卖+黑马点评。这在java技术域里面也就是刚学三四个月的样子,大厂现在招人少,小厂又更加希望你能直接过来干活。就你简历上呈现出来的能力,确实是有点难找,肉眼可见的不懂技术。 第一个项目中:简单的使用redis也算是亮点嘛?使用jwt,threadlocal也算是亮点?你不就是调了几个包嘛?Nginx作为服务器也能写出来,这不是前端的活嘛? 第二个项目中:分布式锁+mq消息队列+Lua队列。真没啥好问的。属于面试官看一眼就阳痿的简历,没有任何想提问的欲望。 我给你建议是好好的挖一挖这个项目吧,其实苍穹外卖和黑马点评这两个项目很不错了,只不过是太烂大街了导致面试官没啥问的兴趣,所以不太推荐写简历上。
点赞 评论 收藏
分享
28小凳也想实习:项目不用一个业务一个轮子吗,刷牛客好多人说要一业务一轮子
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务