leetcode-211. 添加与搜索单词

技术leetcode-211. 添加与搜索单词 leetcode-211. 添加与搜索单词 – 数据结构设计leetcode-211. 添加与搜索单词 – 数据结构设计
题目:
请你设计一个数据结构,支

Leetcode-211。添加和搜索单词-数据结构设计。

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

题目:

请设计一个支持添加新单词的数据结构,并找出字符串是否匹配任何以前添加的字符串。

实现字典类单词字典:

WordDictionary()初始化字典对象。

空添加单词(word)将单词添加到数据结构中,然后就可以匹配了。

如果数据结构中的字符串与word匹配,Bool search(word)返回true否则,返回false。单词可能包含一些“.”,和每个。可以代表任何字母。

思路:

Ontology直接将所有单词存储在数组中,在搜索时遍历所有单词,但这种代码搜索效率低,可能会超时,所以我们可以根据代码对单词进行分类,并存储在map int mapint、vectorstring的数据结构中,其中map的关键是长度,值是对应长度的单词。插入单词时,先计算单词长度,然后再将其插入相应的数组。搜索时,直接根据字长找到对应的集合,遍历集合中的所有单词,然后进行逐字符匹配。如果是“.”,跳过这一次,如果匹配成功,则返回true。

这个问题也可以通过前缀树来解决,因为只有26个单词,所以构造的字典树是一个26分支的树,并且设置了一个标志isEnd来记录这个字母是否是单词的结尾。

数据结构:

类TrieNode{

公众号:

//存储子节点。

vectorTrieNode *子级;

//结束符号。

bool isEnd

TrieNode(){ 0

//初始化子节点。

child=vectorTrieNode * { 26,nullptr };

//默认设置为false,插入时将最后一个字母的标志设置为true。

isEnd=false

};

};

插入元素时,单词通过遍历合并到前缀树中。

当寻找元素时,

如果遍历到单词的末尾,则表示该单词匹配成功,并返回true。

如果单个当前字母为a-z,则递归判断trie-child[word[i]-‘a’]和word[i 1:]的查询结果。

如果当前遍历的字母是“.”,需要递归搜索每个子节点。

Code

地图收藏

类单词词典(}

公众号:

mapint,vectorstring m;

word dictionary(){ 0

}

void addWord(字符串单词){ 0

if(m . count(word . size())==0){ 0

vectorstring cur={ word };

m[word . size()]=cur;

}

else{

m[word.size()]。push_back(单词);

}

}

bool搜索(字符串)

int len=word . size();

if(m . count(len)=0)

返回false

}

for(auto item :m[word . size()]){ 0

bool have=true

for(int I=0;伊琳;I){ 0

if(word[i]!=’.’字[我]!=项目[I]){ 0

have=false

}

}

如果有

返回真;

}

}

返回false

}

};

前缀树

类TrieNode{

公众号:

vectorTrieNode *子级;

bool isEnd

TrieNode(){ 0

child=vectorTrieNode * { 26,nullptr };

isEnd=false

};

};

类单词词典(}

公众号:

TrieNode * root

word dictionary(){ 0

root=new TrieNode();

}

void addWord(字符串单词){ 0

TrieNode * cur=root

for(int I=0;iword . size();I){ 0

if(cur-child[word[I]-‘ a ‘]==nullptr){ 0

cur-child[word[I]-‘ a ‘]=new TrieNode();

}

cur=cur-child[word[I]-‘ a ‘];

}

//结束标志设置为真。

cur-isEnd=true;

};

bool搜索(字符串)

TrieNode * cur=root

//递归查询

返回dfs(cur,0,word);

};

bool dfs(TrieNode* root,int inx,string word){ 0

//找到最后。

if(inx==word . size()){ 0

返回root-isEnd;

};

//当你遇到“.”,您需要遍历所有26个字母一次。

if(word[inx]==’ . ‘){

for(int I=0;i26I){ 0

if(root-child[i]!=nullptr dfs(根-子[i],inx 1,word)){ 0

返回真;

}

}

返回false

}

else{

if(root-child[word[inx]-‘a’]!=nullptr dfs(根-子[word[inx]-‘a’],inx 1,word)){ 0

返回真;

}

返回错误的

};

};

};

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/37487.html

(0)

相关推荐

  • 数据库中常见术语有哪些

    技术数据库中常见术语有哪些这篇文章将为大家详细讲解有关数据库中常见术语有哪些,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Access数据库中有一些常见的术语,下面是小编

    攻略 2021年11月23日
  • web设计模式中的单例模式是什么

    技术web设计模式中的单例模式是什么本篇内容介绍了“web设计模式中的单例模式是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够

    攻略 2021年11月15日
  • Docker原理、架构与应用是什么

    技术Docker原理、架构与应用是什么本篇内容主要讲解“Docker原理、架构与应用是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Docker原理、架构与应用是什么”吧

    攻略 2021年12月13日
  • 手机突然没声音了,手机来电没有声音怎么回事

    技术手机突然没声音了,手机来电没有声音怎么回事原因一:手机设置“静音模式”会造成来电没有声音手机突然没声音了,可以清除小喇叭符合调为响铃模式即可。 原因二:手机设置为“飞行模式”会造成无法接听,轻触关闭“飞行模式”按钮标

    生活 2021年10月31日
  • 我为妈妈做件事作文,帮妈妈擦地作文50个字

    技术我为妈妈做件事作文,帮妈妈擦地作文50个字范文我为妈妈做件事作文:5月9日是母亲节,老师布置了“帮妈妈做一件事”的作业。我不知道该帮妈妈做什么事,就去问爸爸,爸爸说:“可以帮妈妈洗洗碗,或者帮妈妈捶捶背。”我又去问妈

    生活 2021年10月23日
  • 抖音刷粉-抖音刷视频播放量

    技术抖音刷粉-抖音刷视频播放量抖音刷粉-抖音刷视频播放量
    所以如果我们找到一款产品,能够满足这样的需求,完全可以把快手作为一个卖场,因为快手本身商业模式,已经有成熟的趋势。
    抖音是目前及其火爆的短视频APP,伴随着5G时

    测评 2021年11月13日