字典树的使用(匹配子串)

摘要:
=child[i]){deletechild[i];child[i]=NULL;child[iindex]=newTrieNode;memset(root->sz=str[left];flag=true;right;left=0;=right;if(NULL==root||len<=0)returnfalse;}if(num==len)returntrue;

题目:

现有一个小写英文字母组成的字符串s和一个包含较短小写英文字符串的数组p,请设计一个高效算法,对于p中的每一个较短字符串,判断其是否为s的子串。

给定一个string数组p和它的大小n,同时给定string s,为母串,请返回一个bool数组,每个元素代表p中的对应字符串是否为s的子串。

保证p中的串长度小于等于8,且p中的串的个数小于等于500,同时保证s的长度小于等于1000。

此题参考他人代码,使用字典树即可以实现,实在是太赞了。

另外看到类似的做法,为AC自动机,其做法结合了字典树和KMP算法,没看懂,此处就不列出其相关代码。

待后续研究:http://www.cnblogs.com/huangxincheng/archive/2012/12/02/2798317.html

class Substr {

private:
    struct TrieNode {
        char sz;
        bool flag;
        TrieNode* child[26];

        TrieNode():sz(0),flag(false)
        {
            for (size_t i = 0; i < 26; i++)
            {
                child[i] = NULL;
            }
        }

        ~TrieNode()
        {
            for (size_t i = 0; i < 26; i++)
            {
                if (NULL != child[i]) {
                    delete child[i];
                    child[i] = NULL;
                }
            }
        }
    };

    void insert(const string& str,const int& left,const int& right, TrieNode* root) {
        int index = str[left] - 'a';
        if (root->child[index] == NULL) {
            root->child[index] = new TrieNode;
            memset(root->child[index], 0, sizeof(TrieNode));
            root->child[index]->sz = str[left];
        }

        if (left==right)
        {
            root->child[index]->flag = true; 
            return;
        }
        else
        {
            insert(str,left+1,right, root->child[index]);
        }
    }

    void build_TrieNode(const string& str, TrieNode* root)
    {
        int len = str.length(),left,right;
        if (len==0)
            return;

        left = 0;right = len - 1;
        for (; left <= right; left++)
        {
            insert(str, left, right, root);
        }
    }

    bool comparestr(TrieNode* root, const string& str)
    {
        int num = 0, len = str.length(), index;
        if (NULL == root || len <= 0) return false;
        TrieNode* p = root;

        while (p&&num < len)
        {
            index = str[num] - 'a';
            if (p->child[index])
            {
                ++num;
            }
            p = p->child[index];
        }

        if (num == len)
            return true;
        else return false;
    }

public:
    vector<bool> chkSubStr(vector<string> p, int n, string s) {

        vector<bool> res;
        int i, len = p.size(), strlen = s.length();
        if (len <= 0 || strlen <= 0) return res;

        TrieNode *root = new TrieNode;
        memset(root, 0, sizeof(TrieNode));
        build_TrieNode(s, root);

        for ( i = 0; i < len; i++)
        {
            if (comparestr(root, p[i]))
                res.push_back(true);
            else res.push_back(false);
        }

        delete root;
        return res;
    }
};

int main(void)
{
    {
        string str[]{"ello","world","test","hle","aaaa","ld"};
        vector<string> strtemp(str, str + sizeof(str) / sizeof(string));
        Substr test;
        auto var = test.chkSubStr(strtemp, strtemp.size(), "helloworld");
        for each (auto vart in var)
        {
            cout << boolalpha << vart << endl;
        }
    }

    cin.get();
    return 0;
}

免责声明:文章转载自《字典树的使用(匹配子串)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇[转]在AutoCAD中根据MapInfo导出DXF文件块属性填充图斑SSM整合redis下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Vue中使用openlayer做风场图

<template> <div class="box"> <div ref="emap" id="map"></div> <div id="popup" class="ol-popup"> <a href="#" id="popup-closer" class...

iframe: 我们来谈一谈

【转】:https://segmentfault.com/a/1190000004502619#articleHeader6 某大咖说: "iframe是能耗最高的一个元素,请尽量减少使用"某大牛说: "iframe安全性太差,请尽量减少使用"...wtf, 你们知不知道你们这样浇灭了多少孩纸学习iframe的热情和决心。 虽然,你们这样说的我竟无法反驳,...

html5和html的区别

最近看群里聊天聊得最火热的莫过于手机网站和html5这两个词。可能有人会问,这两者有什么关系呢?随着这移动互联网快速发展的时代,尤其是4G时代已经来临的时刻,加上微软对“XP系统”不提供更新补丁、维护的情况下“html5+css3”也逐渐的成为新一代web前端技术,手机网站也渐渐的成为一种趋势。 什么是html5呢? html5最先由WHATWG(Web...

CSS 单行 多行文本溢出显示省略号

单行文本 overflow: hidden; text-overflow:ellipsis; white-space: nowrap; 多行文本溢出显示省略号: <style type="text/css" media="screen"> p { 300px; height: 72px; line-hei...

vue 路由更新页面视图未更新问题

最近项目做面包屑的时候遇到一个问题就是路由变化的时候页面视图并没有发生变化,后来上网查,发现是vue-router的特性导致的。 vue-router的切换不同于传统的页面的切换。路由之间的切换,其实就是组件之间的切换,不是真正的页面切换。这也会导致一个问题,就是引用相同组件的时候,会导致该组件无法更新,也就是我们口中的页面无法更新的问题了。 而我正是因为...

Yarn对外接口

1 概述 Yarn对外接口 https://forum.huawei.com/enterprise/zh/forum.php?mod=viewthread&tid=451687 本文档专供需要对Yarn进行应用开发的用户使用。本指南主要适用于具备Java开发经验的开发人员。 简介 Yarn是一个分布式的资源管理系统,用于提高分布式的集群环境下的资源...