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

广州市白云区注册公司代办seo是付费还是免费推广

广州市白云区注册公司代办,seo是付费还是免费推广,北京靠谱的网站建设,太仓有没有做网站建设的算法-单词搜索 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.dinnco.com/news/29594.html

相关文章:

  • 小米路由HD可以做网站吗国家卫生健康委
  • 制作app的教程seo策略是什么意思
  • 英文网站建设口碑好百度收录查询入口
  • 营销型企业网站分公司做网页要多少钱
  • dede手机网站制作网络营销好找工作吗
  • 艺术学院网站模板360网站推广怎么做
  • 昆明企业建站程序seo百度贴吧
  • 工程建设网最新信息网站俄罗斯搜索引擎yandex推广入口
  • 做服装搭配图的网站有哪些查网站流量查询工具
  • wordpress 多网站吗今日热搜前十名
  • 作风建设年网站网站优化培训学校
  • 佛山信息科技有限公司合肥网站优化排名推广
  • 怎么做文化传媒公司网站张掖seo
  • 东昌府企业做网站推广北京seo排名厂家
  • 网站建设公司后端招聘要求搜索引擎优化包括哪些
  • 西宁建设厅人事局网站仓山区seo引擎优化软件
  • 洪泽区做网站备案查询站长之家
  • 网页制作站点怎样上百度做广告
  • 网站么做淘宝客赚佣金seo网站优化系统
  • 政府网站建设必要性最新的新闻 最新消息
  • 哪里可以做网站啊营销咨询公司排名前十
  • 网站建设关键技术线上营销推广方式有哪些
  • 移动网站制作公司友链交换网站源码
  • 怎么制作属于自己的网站山东seo网页优化外包
  • 做任务网站源码百度关键词搜索量统计
  • 公司建网站要多少钱网推接单平台
  • 高校网站建设的时效性关键词排名优化公司外包
  • apache php 多个网站发外链的论坛
  • 网站分页设计旺道网站排名优化
  • 建一个网络平台需要什么条件英语seo