字典树trie的学习与练习题

博客详解:

http://www.cnblogs.com/huangxincheng/archive/2012/11/25/2788268.html

http://eriol.iteye.com/blog/1166118

http://www.360doc.com/content/12/1116/15/9615799_248213540.shtml

http://www.cnblogs.com/tanky_woo/archive/2010/09/24/1833717.html

http://blog.csdn.net/youngyangyang04/article/details/6840393

 

下面给出一些关于字典树的题目及简略题解:

HDOJ 1251 统计难题:
http://www.wutianqi.com/?p=1364

HDOJ 1671 Phone List
http://www.wutianqi.com/?p=1366

之前打算要写题解的题,但最后就只写了2个,而且是不需用trie树也可以解决的。。。
POJ 2001 AC
POJ 1451 AC 该题是看题解做的。。。
POJ 2513 AC 离散+并查集+欧拉通路(可以不用trie) 有详细题解,请戳 http://www.cnblogs.com/chenxiwenruo/p/3535156.html
POJ 1035 AC 可以用trie模拟,也可以直接暴力比较
POJ 1204 AC 先将要查找的单词建trie树,再扫描整个矩阵,8个方向搜索即可(网上有人说这题可以拿来练AC自动机)
POJ 2004 AC 没用trie树,有详细题解,请戳http://www.cnblogs.com/chenxiwenruo/p/3535794.html
POJ 1816 AC trie+dfs

水题:
POJ 3630/ HDU 1671 AC
POJ 1056 没做,和POJ3630差不多
POJ 2945 没做,就是统计某个字符串出现的次数,可以离散化水过
POJ 3283 看懂后就是一个大水题,从后往前插入即可,没做

当时训练字典树的时候未能解决的题,一直想自己做出来,不看题解, 结果一直到告别ACM也没搞定,其实是后来也没在研究trie树了。。。:POJ 2778,POJ 3376

 

下面给出我当时A题所用的模板,是参考我们学校一个大牛的,网上很多其它人的模板太复杂了。。。

#define maxn 1100000
struct Nod {        //0为无效值
    int lnk[26], val;
    bool isend; //为true的话,则是一个字符串的结尾
    void init() {
        memset(lnk, 0, sizeof(lnk));
        val = 0;
    }
};
const char BASE = 'a';
struct Trie {
    Nod buf[maxn];
    int len;
    void init() {
        buf[len=0].init();
    }
    int insert(char * str, int val) {
        int now = 0;
        for(int i = 0; str[i]; i ++) {
            int & nxt = buf[now].lnk[str[i]-BASE];
            if(!nxt)    buf[nxt=++len].init();
            now = nxt;
        }
        buf[now].val = val;
        return now;
    }
    int search(char * str) {
        int now = 0;
        for(int i = 0; str[i]; i ++) {
            int & nxt = buf[now].lnk[str[i]-BASE];
            if(!nxt)    return 0;
            now = nxt;
        }
        return buf[now].val;
    }
} trie;
View Code

 

转载于:https://www.cnblogs.com/chenxiwenruo/p/4513872.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值