Leetcode 字符流

WechatIMG553.jpeg

题目描述

leetcode 第1032题:字符流
按下述要求实现 StreamChecker 类:
StreamChecker(words):构造函数,用给定的字词初始化数据结构。
query(letter):如果存在某些 k >= 1,可以用查询的最后 k个字符(按从旧到新顺序,包括刚刚查询的字母)拼写出给定字词表中的某一字词时,返回 true。否则,返回 false。
示例:
StreamChecker streamChecker = new StreamChecker(["cd","f","kl"]); // 初始化字典
streamChecker.query('a'); // 返回 false
streamChecker.query('b'); // 返回 false
streamChecker.query('c'); // 返回 false
streamChecker.query('d'); // 返回 true,因为 'cd' 在字词表中
streamChecker.query('e'); // 返回 false
streamChecker.query('f'); // 返回 true,因为 'f' 在字词表中
streamChecker.query('g'); // 返回 false
streamChecker.query('h'); // 返回 false
streamChecker.query('i'); // 返回 false
streamChecker.query('j'); // 返回 false
streamChecker.query('k'); // 返回 false
streamChecker.query('l'); // 返回 true,因为 'kl' 在字词表中。

解题方法

字典树
部分代码语言可能存在超时参照题解

  • 解题思路

构建字典树root,创建双向队列stream
遍历数组words,将每个单词word反转后存入root
每次query时,向stream的左侧插入letter
遍历stream,在root中查询每次输入的letter是否存在

  • 复杂度

时间复杂度:O(n)
空间复杂度:O(n)

  • 代码实现

python3

class Trie:
    def __init__(self):
        self.next = {}
        self.isWrod = False

class StreamChecker:
    def __init__(self, words: List[str]):
        self.root = Trie()
        self.stream = deque([])
        for word in words:
            self.addWord(word)
    
    def addWord(self, word):
        tree = self.root
        for c in word[::-1]:
            if c not in tree.next:
                tree.next[c] = Trie()
            tree = tree.next[c]
        if not tree.isWrod:
            tree.isWrod = True

    def query(self, letter: str) -> bool:
        self.stream.appendleft(letter)
        tree = self.root
        for c in self.stream:
            if c not in tree.next:
                return False
            tree = tree.next[c]
            if tree.isWrod:
                return True
        return False

php

class Trie {
    public $next = [];
    public $isWord = false;
}
class StreamChecker {
    function __construct($words) {
        $this->root = new Trie();
        $this->stream = [];
        array_map([$this,'addWord'],$words);
    }

    function addWord($word){
        $word = strrev($word);
        $tree = $this->root;
        for($i=0;$i<strlen($word);$i++){
            $c = $word[$i];
            if(!isset($tree->next[$c])){
                $tree->next[$c] = new Trie();
            }
            $tree = $tree->next[$c];
        }
        if(!$tree->isWord){
            $tree->isWord = true;
        }
    }
  
    function query($letter) {
        array_unshift($this->stream,$letter);
        print_r($this->stream);
        $tree = $this->root;
        foreach($this->stream as $c){
            if(!isset($tree->next[$c])){
                return false;
            }
            $tree = $tree->next[$c];
            if($tree->isWord){
                return true;
            }
        }
        return false;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值