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

建设银行官方网站企业网银站长之家统计

建设银行官方网站企业网银,站长之家统计,佛山网站建设的大品牌,开一家做网站公司成本算法-单词搜索 II 1 题目概述 1.1 题目出处 https://leetcode.cn/problems/word-search-ii/description/?envTypestudy-plan-v2&envIdtop-interview-150 1.2 题目描述 2 DFS 2.1 解题思路 每个格子往上下左右四个方向DFS,拼接后的单词如果在答案集中&…

算法-单词搜索 II

1 题目概述

1.1 题目出处

https://leetcode.cn/problems/word-search-ii/description/?envType=study-plan-v2&envId=top-interview-150

1.2 题目描述

在这里插入图片描述
在这里插入图片描述

2 DFS

2.1 解题思路

每个格子往上下左右四个方向DFS,拼接后的单词如果在答案集中,则记录下来。

同时为了避免DFS时往回找,需要记录下已访问记录。

2.2 代码

class Solution {private Set<String> wordSet = new HashSet<>();private List<String> resultList = new LinkedList<>();public List<String> findWords(char[][] board, String[] words) {for (String word : words) {wordSet.add(word);}StringBuilder sb = new StringBuilder();char[][] visitSet = new char[board.length][board[0].length];for (int i = 0; i < board.length; i++) {for (int j = 0; j < board[0].length; j++) {dfs(i, j, board, sb, visitSet);}}return resultList;}private void dfs(int i, int j, char[][] board, StringBuilder sb, char[][] visitSet) {if (sb.length() > 10) {return;}if (visitSet[i][j] == 1) {return;}visitSet[i][j] = 1;sb.append(board[i][j]);String currentStr = sb.toString();if (wordSet.contains(currentStr)) {resultList.add(currentStr);wordSet.remove(currentStr);}if (i > 0) {dfs(i - 1, j, board, sb, visitSet);}if (i < board.length - 1) {dfs(i + 1, j, board, sb, visitSet);}if (j > 0) {dfs(i, j - 1, board, sb, visitSet);}if (j < board[0].length - 1) {dfs(i, j + 1, board, sb, visitSet);}sb.deleteCharAt(sb.length() - 1);visitSet[i][j] = 0;}
}

2.3 时间复杂度

在这里插入图片描述
O(M * N * 4^10) 字符串最多10

2.4 空间复杂度

O(10)

3 DFS+Trie树

3.1 解题思路

3.2 代码

class Solution {private Set<String> wordSet = new HashSet<>();private List<String> resultList = new LinkedList<>();public List<String> findWords(char[][] board, String[] words) {for (String word : words) {wordSet.add(word);}StringBuilder sb = new StringBuilder();char[][] visitSet = new char[board.length][board[0].length];for (int i = 0; i < board.length; i++) {for (int j = 0; j < board[0].length; j++) {dfs(i, j, board, sb, visitSet);}}return resultList;}private void dfs(int i, int j, char[][] board, StringBuilder sb, char[][] visitSet) {if (sb.length() > 10) {return;}if (visitSet[i][j] == 1) {return;}visitSet[i][j] = 1;sb.append(board[i][j]);String currentStr = sb.toString();if (wordSet.contains(currentStr)) {resultList.add(currentStr);wordSet.remove(currentStr);}if (i > 0) {dfs(i - 1, j, board, sb, visitSet);}if (i < board.length - 1) {dfs(i + 1, j, board, sb, visitSet);}if (j > 0) {dfs(i, j - 1, board, sb, visitSet);}if (j < board[0].length - 1) {dfs(i, j + 1, board, sb, visitSet);}sb.deleteCharAt(sb.length() - 1);visitSet[i][j] = 0;}
}

3.3 时间复杂度

在这里插入图片描述

4 DFS+Trie树 优化

4.1 解题思路

4.2 代码

class Solution {private List<String> resultList = new LinkedList<>();private TrieNode trieNode = new TrieNode();static class TrieNode {private TrieNode[] trieNodes = new TrieNode[26];public boolean isWord = false;public void insert(String word) {if (word.length() == 0) {isWord = true;return;}int index = word.charAt(0) - 'a';if (null == trieNodes[index]) {trieNodes[index] = new TrieNode();}trieNodes[index].insert(word.substring(1));}}public List<String> findWords(char[][] board, String[] words) {for (String word : words) {trieNode.insert(word);}StringBuilder sb = new StringBuilder();char[][] visitSet = new char[board.length][board[0].length];for (int i = 0; i < board.length; i++) {for (int j = 0; j < board[0].length; j++) {dfs(i, j, board, sb, visitSet, trieNode);}}return resultList;}private void dfs(int i, int j, char[][] board, StringBuilder sb, char[][] visitSet, TrieNode ct) {if (sb.length() > 10) {return;}if (visitSet[i][j] == 1) {return;}visitSet[i][j] = 1;sb.append(board[i][j]);ct = ct.trieNodes[board[i][j] - 'a'];if (null != ct) {if (ct.isWord) {resultList.add(sb.toString());ct.isWord = false;} if (i > 0) {dfs(i - 1, j, board, sb, visitSet, ct);}if (i < board.length - 1) {dfs(i + 1, j, board, sb, visitSet, ct);}if (j > 0) {dfs(i, j - 1, board, sb, visitSet, ct);}if (j < board[0].length - 1) {dfs(i, j + 1, board, sb, visitSet, ct);}}sb.deleteCharAt(sb.length() - 1);visitSet[i][j] = 0;}
}

4.3 时间复杂度

在这里插入图片描述

参考文档

http://www.hengruixuexiao.com/news/6345.html

相关文章:

  • 安阳网站制作网页广告调词平台多少钱
  • 网站群建设项目招标公告百度开户流程
  • 网站后台怎么管理凡科建站
  • 动态网站开发用的程序网络营销技巧和营销方法
  • 做斗图网站uv推广平台
  • 做一年的网站维护价格百度公司有哪些部门
  • 黔江网站制作网站一级域名和二级域名
  • 做门户网站最重要的是什么中国新冠一共死去的人数
  • 金融企业类网站模板免费下载招聘网站排名
  • 页面模板怎么设置优就业seo怎么样
  • 建网站和开发app哪个难免费推广方式有哪些
  • 网站做md5脚本惠州seo快速排名
  • 网站后台分模块星巴克营销策划方案
  • 个人网站做商城会怎样百度seo怎么查排名
  • 旅游网站的设计方案怎么做百度搜索引擎的优缺点
  • 门户网站建设公司报价seo网站推广技术
  • 西宁圆井模板我自己做的网站百度号码
  • 随身办app下载搜索引擎优化的办法有哪些
  • 什么网站可以做线上邀请函sem是什么设备
  • 13个实用平面设计网站调研报告万能模板
  • 用dw做购物网站seo工作是什么意思
  • 济南网站建设0531soso网站推广的方法有哪些?
  • 帮人做网站要怎么赚钱今日头条国际新闻
  • 黑龙江省网站备案网页查询
  • 网站开发语言netseo怎么做推广
  • 教育 wordpress模板seo sem是指什么意思
  • 做环保工程常用的网站故事式软文范例100字
  • 网站建设查询移动网站优化排名
  • 不属于企业网站建设基本标准是网站推广应该坚持什么策略
  • 龙口网站建设联系电话如何做网站推广私人