博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Trie树
阅读量:4313 次
发布时间:2019-06-06

本文共 1519 字,大约阅读时间需要 5 分钟。

很多时候以为自己能记得做过的题目,可是实际上做过了几乎就不记得了。。。。。。。sad,于是还是记录一下吧。

 

题目:

对于小Hi的每一个询问,输出一个整数Ans,表示词典中以小Hi给出的字符串为前缀的单词的个数。

样例输入

5babaabbabbbaaaaabbaaaaaabaababaababb5babbbaabaaababbbbbabbaab 算法: 记录一个Trie树,trie树的struct的内容包括,节点的内容,Trie *next[26],因为有26个字母,一个ans记录访问过的次数。 分为两步,1:依次读取每条字符串,记录节点,若节点数据为null则记录,对于每个字符cnt++。 2.判断出现的次数,直接依次读取,知道访问到了那个节点,得到节点的cnt. 实现:
1 #include 
2 #include
3 #include
4 #include
5 using namespace std; 6 const int MAXN=105; 7 8 struct Trie{ 9 char ch;10 int cnt;11 Trie *next[26];12 Trie(){13 cnt=0;14 for(int i=0;i<26;i++){15 next[i]=NULL;16 }17 }18 };19 Trie root;20 int ans;21 void insertWord(char *str){22 int len=strlen(str);23 Trie *head=&root;24 for(int i=0;i
next[idx]==NULL){27 Trie * node=new Trie;28 node->ch=str[i];29 head->next[idx]=node;30 }31 head=head->next[idx];32 head->cnt++;33 34 }35 }36 void queryWord(char *str){37 Trie* head=&root;38 int len=strlen(str);39 ans=0;40 for(int i=0;i
next[idx]==NULL)return ;43 else{44 head=head->next[idx];45 }46 }47 ans=head->cnt;48 }49 int main(int argc, const char * argv[]) {50 char str[MAXN];51 int n,m;52 cin>>n;53 for(int i=0;i
>str;55 insertWord(str);56 }57 cin>>m;58 for(int i=0;i
>str;60 ans=0;61 queryWord(str);62 cout<
<

 

 

转载于:https://www.cnblogs.com/bounceFront/p/5518880.html

你可能感兴趣的文章
C++——string类和标准模板库
查看>>
zt C++ list 类学习笔记
查看>>
git常用命令
查看>>
探讨和比较Java和_NET的序列化_Serialization_框架
查看>>
1、jQuery概述
查看>>
数组比较大小的几种方法及math是方法
查看>>
FTP站点建立 普通电脑版&&服务器版
查看>>
js 给一段代码,给出运行后的最终结果的一些综合情况、
查看>>
webservice 详解
查看>>
js自动补全实例
查看>>
VS无法启动调试:“生成下面的模块时,启用了优化或没有调试信息“
查看>>
npm 安装 sass=-=-=
查看>>
WINFORM中加入WPF控件并绑定数据源实现跨线程自动更新
查看>>
C#类对象的事件定义
查看>>
各类程序员学习路线图
查看>>
HDU 5510 Bazinga KMP
查看>>
关于select @@IDENTITY的初识
查看>>
ASP.NET MVC ajax提交 防止CSRF攻击
查看>>
关于CSS伪类选择器
查看>>
适用于带文字 和图片的垂直居中方法
查看>>