当前位置: 首页 > news >正文

郴州网站建设推广方案怎么建立一个自己的网站

郴州网站建设推广方案,怎么建立一个自己的网站,wordpress国外主题公园,广州网页设计工资深度优先搜索|79. 单词搜索, 695. 岛屿的最大面积, 212. 单词搜索 II 单词搜索岛屿的最大面积单词搜索II 单词搜索 用的是深度优先搜索,这种判断类型的回溯我就一直不知道要怎么回退,然后勉强写了一个。 这里还有一个注意事项就是,走到最后一…

深度优先搜索|79. 单词搜索, 695. 岛屿的最大面积, 212. 单词搜索 II

  • 单词搜索
  • 岛屿的最大面积
  • 单词搜索II

单词搜索

用的是深度优先搜索,这种判断类型的回溯我就一直不知道要怎么回退,然后勉强写了一个。
这里还有一个注意事项就是,走到最后一个元素的时候,我设置的direction list里头就只有用过的几个元素,再加上我写的if used这个时候他就走不下去了,也不会到下一层的index+1了,这个时候又可以观察到,如果走到最后有一个元素了和word也对得上其实并不需要再去看有没有direction了,直接去index+1不用管i,j是谁就能直接True,所以这个地方可以加一个判断就是如果走到这里已经在word最后一个字母后面了,直接True。
然后写到这里就会发现,如果直接出去了,那么

if index == len(word):return True 

这句好像根本不需要,后来发现确实不需要。

class Solution:def exist(self, board: List[List[str]], word: str) -> bool:def direction(i,j,m,n):l = [[i-1,j],[i+1,j],[i,j-1],[i,j+1]]if i == 0:l.remove([i-1,j])if j == 0:l.remove([i,j-1])if i == m-1:l.remove([i+1,j])if j == n-1:l.remove([i,j+1])return l def backtracking(index,i,j):#if index == len(word):#return True l = direction(i,j,m,n)if board[i][j] != word[index]: return Falseused[i][j] = Truefor k1,k2 in l:if index == len(word) - 1:return True if used[k1][k2]: continueif backtracking(index+1,k1,k2):return Trueif l == [] and index == len(word)-1:return Trueused[i][j] = Falsereturn Falsem = len(board)n = len(board[0])used = [[False]*n for _ in range(m)]for i in range(m):for j in range(n):if backtracking(0,i,j):return True return False

岛屿的最大面积

这个题没上面的难,因为他知道是1都是连着的,所以不用回退。

class Solution:def maxAreaOfIsland(self, grid: List[List[int]]) -> int:def direction(i,j,m,n):l = [[i-1,j],[i+1,j],[i,j-1],[i,j+1]]if i == 0:l.remove([i-1,j])if j == 0:l.remove([i,j-1])if i == m-1:l.remove([i+1,j])if j == n-1:l.remove([i,j+1])return l m = len(grid)n = len(grid[0])used = [[False]*n for _ in range(m)]def backtracking(i,j):nonlocal resif grid[i][j] == 0: return 0l = direction(i,j,m,n)res += 1used[i][j] = Truefor k1,k2 in l:if used[k1][k2]:continuebacktracking(k1,k2)return island = 0for i in range(m):for j in range(n):res = 0backtracking(i,j)island = max(island,res)return island

单词搜索II

在上一题的基础上加了一层循环,然后剪枝了一下,大多数还是能运行,就是太长了就超时了
42 / 65,这里有个要点是,每次单词的used list都要重新设,不然路都堵死了。

class Solution:def findWords(self, board: List[List[str]], words: List[str]) -> List[str]:def direction(i,j,m,n):l = [[i-1,j],[i+1,j],[i,j-1],[i,j+1]]if i == 0:l.remove([i-1,j])if j == 0:l.remove([i,j-1])if i == m-1:l.remove([i+1,j])if j == n-1:l.remove([i,j+1])return l def backtracking(index,word,i,j):l = direction(i,j,m,n)if board[i][j] != word[index]: return Falseused[i][j] = Truefor k1,k2 in l:if index == len(word) - 1:return True if used[k1][k2]: continueif backtracking(index+1,word,k1,k2):return Trueif l == [] and index == len(word)-1:return Trueused[i][j] = Falsereturn Falsem = len(board)n = len(board[0])res = []for k in words:used = [[False]*n for _ in range(m)]for i in range(m):if k in res:breakfor j in range(n):#print(i,j,k,res)if k in res:breakif backtracking(0,k,i,j):res.append(k)
http://www.zhongyajixie.com/news/4651.html

相关文章:

  • 男女在床上做暖暖插孔网站关键词排名什么意思
  • 做网站淮南网络公关
  • 建设网站需求亚马逊查关键词搜索量的工具
  • 邯郸怎么做网站南京seo关键词优化预订
  • 网站域名分几种关键词歌词打印
  • 长春制作网站定制台州seo排名扣费
  • 电商公司的网站设计书seo网站培训优化怎么做
  • 上海企业网站制作费用如何做seo搜索优化
  • 美工做的好的网站最近发生的热点新闻
  • 心悦会员免做卡网站常州seo外包公司
  • 网站建设印花税品牌营销策划培训课程
  • 网站新闻百度收录友情链接的形式有哪些
  • 网站建设的费用是多少钱武汉网站建设公司
  • 福田网站建设设计公司链接买卖
  • 免费做团购网站的软件想做网站找什么公司
  • 含山微信搭建网站建设全媒体广告代理加盟
  • 永久免费手机网站建设百度客服电话是多少
  • 做便宜网站产品推广建议
  • 黄岛开发区做网站网络公司dz论坛seo设置
  • 北京网站建设资讯黄冈网站推广软件有哪些
  • 宁波智能模板建站百度人工客服电话24小时
  • 金融网站框架模板下载重庆seo整站优化方案范文
  • 学校网站的建设需求长沙县网络营销咨询
  • 网站编辑转行做文案百度快快速排名
  • 公司网站怎么做才能吸引人深圳关键词优化软件
  • 京网站建设公司培训班该如何建站
  • 网站改版要多少钱域名备案查询官网
  • 域名 网站微信管理系统登录
  • 怎么建立网站的流程百度云搜索引擎 百度网盘
  • 网络工程建设aso优化教程