字典树的实现
    假设组成所有单词的字符仅是‘a’~‘z’,请实现字典树的结构,并包含以下四个主要的功能。
    1. void insert(String word):添加word,可重复添加;
    2. void delete(String word):删除word,如果word添加过多次,仅删除一次;
    3. boolean search(String word):查询word是否在字典树中出现过(完整的出现过,前缀式不算);
    4. int prefixNumber(String pre):返回以字符串pre作为前缀的单词数量。
    现在给定一个m,表示有m次操作,每次操作都为以上四种操作之一。每次操作会给定一个整数op和一个字符串word,op代表一个操作码,如果op为1,则代表添加word,op为2则代表删除word,op为3则代表查询word是否在字典树中,op为4代表返回以word为前缀的单词数量(数据保证不会删除不存在的word)。
    对于每次操作,如果op为3时,如果word在字典树中,请输出“YES”,否则输出“NO”;如果op为4时,请输出返回以word为前缀的单词数量,其它情况不输出。

    示例 输入:[[“1”,”qwer”],[“1”,”qwe”],[“3”,”qwer”],[“4”,”q”],[“2”,”qwer”],[“3”,”qwer”],[“4”,”q”]] 输出:[“YES”,”2”,”NO”,”1”]

    数据范围:操作数满足 (牛客)字典树的实现🏷字符串🏷字典树 - 图1,字符串长度都满足 (牛客)字典树的实现🏷字符串🏷字典树 - 图2

    进阶:所有操作的时间复杂度都满足 (牛客)字典树的实现🏷字符串🏷字典树 - 图3