博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
字典树模板
阅读量:4205 次
发布时间:2019-05-26

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

今天AC了两题trie tree的题目,感觉trie的性质真的是相当的好,而且实现比较简单。它使在字符串集合中查找某个字符串的操作的复杂度降到最大只需O(n),其中n为字符串的长度。trie是典型的将时间置换为空间的算法,好在ACM中一般对空间的要求很宽松。

#include
#include
using namespace std;class trie{public: trie* next[26]; int num; //记录前缀的个数 bool value; //标记这里是不是一个单词 trie() { for(int i=0;i<26;i++) next[i]=0; value=0; num=0; }}root;void insert(char* s){ trie *p=&root; int k=0; while(s[k]!='\0') { if(!p->next[s[k]-'a']) p->next[s[k]-'a']=new trie; p=p->next[s[k]-'a']; p->num++; 每访问节点就++1次,多好啊! k++; } p->value=1; //在这里可根据具体题意来加东西}int find(char *s){ trie* p=&root; int k=0; while(s[k]!='\0'&&p->next[s[k]-'a']) { p=p->next[s[k]-'a']; k++; } if(s[k]=='\0') return p->num; return 0;}int main(){ char english[12],martian[12],word[12]; while(gets(english)&&english[0]!='\0') { insert(english); } while(scanf("%s",martian)!=EOF) { cout<
<
说明:这题是1组的数据的,如果是多组数据,要在主函数里加上:
---------------------------------------------
trie *p=&root;char ask1[20000];while(){For(){insert(p,ask1); find(p,ask1); } P=new trie();//注意这里  多组数据要建多个树}  ---------------------------------------同时还要修改insert(trie *p,char *s)             Find(trie *p,char *s)
----------------------------------------

自己做题体会吧!

练习题目:所有字符串的题目,可以考虑用trie!

HDU:1251,1075,1800,2072都是。

陈宇老师写的,非常好!

转载地址:http://jcali.baihongyu.com/

你可能感兴趣的文章
PHP在变量前面加&是什么意思?
查看>>
ebay api - GetUserDisputes 函数
查看>>
ebay api GetMyMessages 函数
查看>>
php加速器 - zendopcache
查看>>
手动12 - 安装php加速器 Zend OPcache
查看>>
set theme -yii2
查看>>
yii2 - 模块(modules)的view 映射到theme里面
查看>>
yii2 - controller
查看>>
yii2 - 增加actions
查看>>
网站加载代码
查看>>
php图像处理函数大全(缩放、剪裁、缩放、翻转、旋转、透明、锐化的实例总结)
查看>>
magento url中 uenc 一坨编码 base64
查看>>
强大的jQuery焦点图无缝滚动走马灯特效插件cxScroll
查看>>
Yii2.0 数据库查询
查看>>
yii2 db 操作
查看>>
mongodb group 有条件的过滤组合个数。
查看>>
yii2 用命令行操作web下的controller
查看>>
yii2 console的使用
查看>>
关于mongodb的 数组分组 array group
查看>>
MongoDB新的数据统计框架介绍
查看>>