zoukankan      html  css  js  c++  java
  • 从0开始 数据结构 字典树 hdu1251

    字典树

    知识补充

    ‘’和‘ ’的区别

    '' 是一个字符串的结尾

    ' ' 是换行符

    gets 和 scanf 的区别
    gets()函数总结:
    • gets() 从标准输入设备读取字符串,以回车结束读取,使用''结尾,回车符' '被舍弃没有遗留在缓冲区。

    • 可以用来输入带空格的字符串。

    • 可以无限读取,不会判断上限,因此使用gets不安全,可能会造成溢出

    scanf()函数总结:
    • scanf() 以 空格 或 回车符 结束读取,空格 或 回车符 会遗留在缓冲区。

    • 不能直接输入带空格的字符串

    所以遇到题设这种条件一开始用gets之后再用scanf

    推荐学习博客

    Trie树

    是一种树形结构,是一种哈希树的变种。典型应用是用于统计,排序和保存大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计。它的优点是:利用字符串的公共前缀来节约存储空间,最大限度地减少无谓的字符串比较,查询效率比哈希表高。

    hdu 1251统计难题

    题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=1251)

    Problem Description

    Ignatius最近遇到一个难题,老师交给他很多单词(只有小写字母组成,不会有重复的单词出现),现在老师要他统计出以某个字符串为前缀的单词数量(单词本身也是自己的前缀).

    Input

    输入数据的第一部分是一张单词表,每行一个单词,单词的长度不超过10,它们代表的是老师交给Ignatius统计的单词,一个空行代表单词表的结束.第二部分是一连串的提问,每行一个提问,每个提问都是一个字符串.

    注意:本题只有一组测试数据,处理到文件结束.

    Output

    对于每个提问,给出以该字符串为前缀的单词的数量.

    Sample Input

    banana

    band

    bee

    absolute

    acm

    ba

    b

    band

    abc

    Sample Output

    2

    3

    1

    0

    选择C++

    状态: accepted

    代码如下:

    //×ÖµäÊ÷ѧϰ
    #include <iostream>
    #include <cstdio>
    #include <cstring>
    
    using namespace std;
    const int maxn = 26;
    struct trie
    {
        trie* nex[maxn];
        int v;
        bool isEnd;
        trie()
        {
            for(int i = 0 ; i < maxn; i++)
                nex[i] = NULL;
            v = 1;
            isEnd = 0;
            //init as 1 but when it is end, v = -1
        }
    };
    trie root;
    
    void createTrie(char * str)
    {
        int len = strlen(str);
        trie* p = &root, *q;
        for(int i= 0; i < len ; i++)
        {
            int tmp = str[i] - 'a';
            if(p->nex[tmp] == NULL)
            {
                q = new trie;
                p->nex[tmp] = q;
                p = p->nex[tmp];
            }
            else
            {
                p->nex[tmp]->v++;
                p = p->nex[tmp];
            }
        }
        p->isEnd = 1;
    }
    int findTrie(char *str)
    {
        int len = strlen(str);
        trie* p = &root;
        for(int i = 0; i < len ; i++)
        {
            int tmp = str[i]-'a';
            p = p->nex[tmp];
            if(p == NULL)
                return 0;//not exist
        }
        return p->v;//it is prefix of the set
    }
    int dealTrie(trie * root)
    {
        if(root == NULL)
            return 0;
        for(int i = 0 ; i < maxn ; i++)
        {
            if(root->nex[i] != NULL)
                dealTrie(root->nex[i]);
        }
        delete root;
        return 0;
    }
    
    int main()
    {
    //    freopen("in.txt","r",stdin);
        char ss[maxn];
        while(gets(ss) && ss[0]!='')
            createTrie(ss);
    //    while(~scanf("%s",ss) && ss[0] != '')
    //    {
    //        createTrie(ss);
    //        printf("%s
    ",ss);
    //    }
        memset(ss,0,sizeof(ss));
        while(scanf("%s",ss)!= EOF)
        {
            cout << findTrie(ss) << endl;
        }
    //    dealTrie(&root);
        return 0;
    }
    
    
  • 相关阅读:
    《白骨精学习法》 21世纪职场必备学习技巧
    英雄不问出处
    整理ArcSDE 安装过程出现问题以及解决方法系列
    ArcEngine9.1结合VS2005开发技巧2则
    推荐一界面控件DotNetBar(含附件)
    常用易忘记Oracle命令(待续)
    ArcSDE中间件技术的生命力(蔡晓兵)
    ArcSDE 的存储机制
    (收藏)ITPUB的ORACLE之常用FAQ V1.0
    ORA01691错误
  • 原文地址:https://www.cnblogs.com/pprp/p/7801211.html
Copyright © 2011-2022 走看看