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

211. 添加与搜索单词 - 数据结构设计

https://leetcode.cn/problems/design-add-and-search-words-data-structure/description/?envType=study-plan-v2&envId=top-interview-150

思路:就是然我们设计一个字典树,和上一题基本一样,之前使用的是树的方式来构建字典树。

class Main{class WordDictionary {private WordDictionary[] children;private boolean isEnd;public WordDictionary() {this.children = new WordDictionary[26];this.isEnd = false;}public void addWord(String word) {WordDictionary node = this;for (int i = 0; i < word.length(); i++) {char ch = word.charAt(i);int index = ch - 'a';if (node.children[index] == null) {node.children[index] = new WordDictionary();}node = node.children[index];}node.isEnd = true;}public boolean search(String word) {WordDictionary node = this;return search2(node, word, 0);}public boolean search2(WordDictionary node, String word, int index) {if(index == word.length()) {return node.isEnd;}//遇到'.' 的逻辑:遍历该层的所有非空节点只要所有情况中存在匹配情况就返回true(意思就是只有true才是终点)char ch = word.charAt(index);if(ch == '.') {for(WordDictionary child : node.children) {if( child != null) {if(search2(child, word, index + 1)) {return true;}}}} else {if(node.children[ch - 'a'] != null && search2(node.children[ch - 'a'], word, index + 1)) {return true;}}return false;}}public static void main(String[] args) {Main main = new Main();WordDictionary wordDictionary = main.new WordDictionary();wordDictionary.addWord("bad");wordDictionary.addWord("dad");wordDictionary.addWord("mad");System.out.println(wordDictionary.search("pad")); // return falseSystem.out.println(wordDictionary.search("bad")); // return trueSystem.out.println(wordDictionary.search(".ad")); // return trueSystem.out.println(wordDictionary.search("b..")); // return true}}

相关文章:

  • Axure高保真CRM客户关系管理系统原型
  • Vue常用自定义指令-积累的魅力【VUE】
  • 如何备份和恢复Linux系统?
  • 生产环境CPU飙升问题排查与优化实战
  • 超越感官的实相:声、光、气味的科学与哲学探微
  • 文章记单词 | 第103篇(六级)
  • MYSQL优化(1)
  • Science Robotics|仿生章鱼机器人问世:流体智能分级操控,抓豆腐、测触感全自动
  • Mybatis-入门程序、 数据库连接池、XML映射配置文件、MybatisX
  • Ubuntu 24-部署FTP和自定义用户
  • 【JavaScript篇】对象武林:构造函数创世录与实例江湖风云
  • 根据YOLO数据集标签计算检测框内目标面积占比(YOLO7-10都适用)
  • 马里兰大学飞行模拟和控制实验室突破性XR研究
  • 基于51单片机和8X8点阵屏、独立按键的飞行躲闪类小游戏
  • python学习day2:运算符+优先级
  • 《Medical SAM适配器:将分割一切模型适配于医学图像分割》|文献速递-深度学习医疗AI最新文献
  • 2025 最新 Redis 面试题大全
  • 海拔案例分享-实践活动报名测评小程序
  • STM32+腾讯物联网平台OTA升级详细教程
  • STM32 TIM 定时器深度剖析:结构、时基、中断与应用开发(超形象详解)
  • 分析网站的外链/银徽seo
  • 重庆招工招聘信息查询/手机系统优化软件哪个好
  • 在那里做网站/客户管理系统
  • 济南网站优化网站/网店推广有哪些方法
  • 企业网站建设公司有哪些/宁波企业seo推广
  • 哪个网站做任务赚钱的/seo网站搜索优化