Algorithms(字典树)

字典树

#ifndef TIRE_H_INCLUDED
#define TIRE_H_INCLUDED

/*
** 字典树
*/
#define MAX 26

typedef struct Node
{
    int num;
    struct Node* next[MAX];
}Tire;

/*
** 创建一个节点
*/
Tire* create(void);

/*
** 插入一个字符串
*/
Tire* insert(char str[], Tire* head);

/*
** 搜索字符串
*/
int search(char str[], Tire* head);

#endif // TIRE_H_INCLUDED
/*----------------------------------------------------------------------------------
 * Project: Tire.cpp
 * Name: zwp
 * Date: 2014/5
 *---------------------------------------------------------------------------------*/

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include "Tire.h"
#include <malloc.h>

/*
** 创建一个节点
*/
Tire* create(void)
{
    int i;

    Tire* node = (Tire*)malloc(sizeof(Tire));
    if(node == NULL)
        printf("Out of space...\n");

    /* 初始化 */
    for(i = 0; i < MAX; ++ i)
        node->next[i] = NULL;
    node->num = 0;

    return node;
}

/*
** 插入一个字符串
*/
Tire* insert(char str[], Tire* head)
{
        int i, len = strlen(str);
        Tire *node, *ptr = head;

        for(i = 1; i < len; ++ i)
        {
            int count = str[i] - 'a';
            /* 若不存在该字符串 */
            if(ptr->next[count] == NULL)
            {
                node = create();
                ptr->next[count] = node;
                ptr->num++;
                ptr = ptr->next[count];
            }
            /* 若存在该字符串 */
            else
            {
                ptr = ptr->next[count];
            }
        }
}

/*
** 搜索字符串,返回该字符串出现的次数
*/
int search(char str[], Tire* head)
{
    Tire* ptr = head;
    int len = strlen(str);
    int i, count = 0;

    for(i = 0; i < len; ++ i)
    {

        int cou = str[i] - 'a';
        if(ptr->next[cou] == NULL)
        {
            printf("不存在该字符串\n");
            count = 0;
            return 0;
        }
        else
        {
            ptr = ptr->next[cou];
            count = ptr->num;
        }
    }
    return count;

}
/*------------------------------------------------------------------------------
 * Project: Main.cpp
 * Name: zwp
 * Date: 20145/
 *------------------------------------------------------------------------------*/

 #include "Tire.h"
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>

 int main(int argc, char* argv[])
 {

    Tire* node = create();
    char str[10];

    while(scanf("%s\n", str) )
    {
       if(strcmp(str, "quit") == 0)
            break;
        insert(str, node);

    }

    int count = search("a", node);
    printf("%d\n", count);

     system("pause");
     return 0;

 }

Algorithms(字典树),布布扣,bubuko.com

时间: 2024-08-23 20:28:36

Algorithms(字典树)的相关文章

跳跃表,字典树(单词查找树,Trie树),后缀树,KMP算法,AC 自动机相关算法原理详细汇总

第一部分:跳跃表 本文将总结一种数据结构:跳跃表.前半部分跳跃表性质和操作的介绍直接摘自<让算法的效率跳起来--浅谈"跳跃表"的相关操作及其应用>上海市华东师范大学第二附属中学 魏冉.之后将附上跳跃表的源代码,以及本人对其的了解.难免有错误之处,希望指正,共同进步.谢谢. 跳跃表(Skip List)是1987年才诞生的一种崭新的数据结构,它在进行查找.插入.删除等操作时的期望时间复杂度均为O(logn),有着近乎替代平衡树的本领.而且最重要的一点,就是它的编程复杂度较同类

字典树(Trie)的基本实现(C++)

简要说明一下: 主要实现了两个操作,get,set get用来查找字符串键值对应的value,set则用来向字典树添加key-value对. 这个实现参考自Algorithms 4th Edition, Robert Sedgewick const int inf = -(1 << 30); struct Node{ int val; Node** next; Node(){ val = -(1 << 30); next = new Node*[256]; for (int i =

BNU 27847——Cellphone Typing——————【字典树】

Cellphone Typing Time Limit: 5000ms Memory Limit: 131072KB This problem will be judged on UVA. Original ID: 1252664-bit integer IO format: %lld      Java class name: Main Prev Submit Status Statistics Discuss Next Type: None None Graph Theory 2-SAT A

hdu 1251 统计难题(字典树)

Problem Description Ignatius最近遇到一个难题,老师交给他很多单词(只有小写字母组成,不会有重复的单词出现),现在老师要他统计出以某个字符串为前缀的单词数量(单词本身也是自己的前缀). Input 输入数据的第一部分是一张单词表,每行一个单词,单词的长度不超过10,它们代表的是老师交给Ignatius统计的单词,一个空行代表单词表的结束.第二部分是一连串的提问,每行一个提问,每个提问都是一个字符串. 注意:本题只有一组测试数据,处理到文件结束. Output 对于每个提

51nod round3# 序列分解(折半枚举+字典树)

小刀和大刀是双胞胎兄弟.今天他们玩一个有意思的游戏. 大刀给小刀准备了一个长度为n的整数序列.小刀试着把这个序列分解成两个长度为n/2的子序列. 这两个子序列必须满足以下两个条件: 1.他们不能相互重叠. 2.他们要完全一样. 如果小刀可以分解成功,大刀会给小刀一些糖果. 然而这个问题对于小刀来说太难了.他想请你来帮忙. Input 第一行给出一个T,表示T组数据.(1<=T<=5) 接下来每一组数据,输入共2行. 第一行包含一个整数n (2<=n<=40且为偶数). 第二行给出n

白话算法与数据结构之【字典树】

1. 什么是trie树 1.Trie树 (特例结构树) Trie树,又称单词查找树.字典树,是一种树形结构,是一种哈希树的变种,是一种用于快速检索的多叉树结构.典型应用是用于统计和排序大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计.它的优点是:最大限度地减少无谓的字符串比较,查询效率比哈希表高.      Trie的核心思想是空间换时间.利用字符串的公共前缀来降低查询时间的开销以达到提高效率的目的. Trie树也有它的缺点,Trie树的内存消耗非常大.当然,或许用左儿子

[算法系列之二十]字典树(Trie)

一 概述 又称单词查找树,Trie树,是一种树形结构,是一种哈希树的变种.典型应用是用于统计,排序和保存大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计. 二 优点 利用字符串的公共前缀来减少查询时间,最大限度地减少无谓的字符串比较,查询效率比哈希表高. 三 性质 (1)根节点不包含字符,除根节点外每一个节点都只包含一个字符: (2)从根节点到某一节点,路径上经过的字符连接起来,为该节点对应的字符串: (3)每个节点的所有子节点包含的字符都不相同. 单词列表为"apps&

poj 3764 The xor-longest Path(字典树)

题目链接:poj 3764 The xor-longest Path 题目大意:给定一棵树,每条边上有一个权值,找出一条路径,使得路径上权值的亦或和最大. 解题思路:dfs一遍,预处理出每个节点到根节点路径的亦或和rec,那么任意路径均可以表示rec[a] ^ rec[b],所以问题 就转换成在一些数中选出两个数亦或和最大,那么就建立字典树查询即可. #include <cstdio> #include <cstring> #include <algorithm> us

字典树

字典树(Trie)是一种很特别的树状信息检索数据结构,如同其名,它的构成就像一本字典,可以让你快速的进行字符插入.字符串搜索等. Trie 一词来自 retrieval,发音为 /tri:/ "tree",也有人读为 /tra?/ "try". 字典树设计的核心思想是空间换时间,所以数据结构本身比较消耗空间.但它利用了字符串的共同前缀(Common Prefix)作为存储依据,以此来节省存储空间,并加速搜索时间.Trie 的字符串搜索时间复杂度为 O(m),m 为最