青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

pku 1816 wild words trie樹的活用

題意:
模板包括3種字符:
a-z:標準字符
通配符?,代表任意一個字符
*:代表0個或多個字符

先給出n個模板串,m個字符串,問每個字符串分別匹配那幾個模板串
n<=1e6,m<=1e2,strlen<20

解法:
用trie樹構建模板串,然后再dfs來匹配
應為模板串中有重復串,一個簡單的方法是,開辟一個鏈表空間,鏈接每個模板串的末節(jié)點
然后判斷每個字符串時DFS一次,將能到達的尾部節(jié)點做個標記,然后根據(jù)之前記錄的鏈表掃一遍就知道到達過哪些模板串的根節(jié)點(匹配了哪些模板串)
DFS的時候要注意下幾點:
1、狀態(tài)設定:(節(jié)點編號、當前字符串位置)
2、如果當前節(jié)點中存在'?"的轉移路徑,則轉移過去
3、如果當前節(jié)點存在'*'的轉移路徑,枚舉*匹配的長度,然后轉移
總復雜度1e7左右。。。不知道有什么好的方法,我的程序C++跑了400MS。。。不算快的。。

另外,這題建議用動態(tài)內存分配,我開始開了100W的buffer,竟然MLE。。。。
代碼:
 1# include <cstdio>
 2# include <cstring>
 3# include <cstdlib>
 4
 5using namespace std;
 6struct node
 7{
 8    node *nxt[28];
 9    bool in;
10    node()
11    {
12          memset(nxt,NULL,sizeof(nxt));
13          in=false;
14    }

15}
*ans[100005],head;
16char map[255];
17int c=1;
18node* insert(char *str)
19{
20   node *p=&head;
21   for(int i=0;str[i]!='\0';i++)
22   {
23      if(p->nxt[map[str[i]]]==NULL)
24         p->nxt[map[str[i]]]=new node();
25      p=p->nxt[map[str[i]]];
26   }

27   return p;
28}

29void match(node *p,char *str)
30{
31     if(!p) return;
32     if(*str=='\0')
33     {
34        p->in=true;
35        match(p->nxt[27],str);
36     }

37     else
38     {
39         match(p->nxt[map[*str]],str+1);
40         match(p->nxt[26],str+1);
41         for(int i=0;i<=strlen(str);i++)
42           match(p->nxt[27],str+i);
43     }

44}

45int main()
46{
47    int n,m;
48    for(int i='a';i<='z';i++)
49       map[i]=i-'a';
50    map['?']=26;
51    map['*']=27;
52    scanf("%d%d",&n,&m);
53    for(int i=0;i<n;i++)
54    {
55       char str[10];
56       scanf("%s",str);
57       ans[i]=insert(str);
58    }

59    for(int i=0;i<m;i++)
60    {
61        for(int j=0;j<n;j++) ans[j]->in=false;
62        char str[128];
63        scanf("%s",str);
64        match(&head,str);
65        bool flag=false;
66        for(int j=0;j<n;j++)
67          if(ans[j]->in)
68           {
69              flag=true;
70              printf("%d ",j);
71           }

72        if(flag) printf("\n");
73        else printf("Not match\n");
74    }

75  // system("pause");
76    return 0;
77}

78

posted on 2011-01-13 18:05 yzhw 閱讀(279) 評論(0)  編輯 收藏 引用 所屬分類: search 、string algorithm

<2011年1月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
303112345

導航

統(tǒng)計

公告

統(tǒng)計系統(tǒng)

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            激情五月综合色婷婷一区二区| 亚洲一区二区av电影| 亚洲午夜免费视频| 亚洲风情在线资源站| 午夜精品在线视频| 亚洲视频你懂的| 一区二区三区日韩在线观看| 99精品欧美一区| 中文一区在线| 亚洲欧美在线视频观看| 亚洲欧美视频在线观看视频| 亚洲欧美日本视频在线观看| 亚洲一区欧美一区| 午夜影视日本亚洲欧洲精品| 亚洲欧美在线x视频| 久久精品一本| 蜜臀av性久久久久蜜臀aⅴ| 欧美freesex交免费视频| 亚洲精品欧美日韩| 亚洲一区视频| 久久精品99无色码中文字幕| 欧美福利影院| 国产伦精品一区二区三区视频孕妇| 国产欧美日韩精品一区| 亚洲人成免费| 蜜臀久久99精品久久久久久9 | 欧美久久久久久久久| 国产精品国产一区二区| 亚洲第一天堂无码专区| 亚洲欧美欧美一区二区三区| 麻豆91精品| 久久成人综合网| 一区二区三区视频在线播放| 亚洲一区三区视频在线观看| 欧美国产三区| 亚洲黄色精品| 欧美国内亚洲| 蜜桃视频一区| 中文av字幕一区| 91久久国产精品91久久性色| 久久久国产视频91| 国语自产精品视频在线看抢先版结局| 亚洲欧美国产高清| 亚洲激情一区二区| 欧美成人综合网站| 欧美久久一级| 欧美一级播放| 免费精品视频| 亚洲一卡久久| 久久久久久穴| 一本色道精品久久一区二区三区 | 韩国三级在线一区| 欧美国产日韩在线| 欧美精品色一区二区三区| 亚洲影院一区| 老司机精品导航| 亚洲香蕉伊综合在人在线视看| 亚洲视频电影图片偷拍一区| 国产欧美日韩免费| 日韩写真视频在线观看| 国产精品卡一卡二卡三| 久久久久www| 欧美日本一道本| 久久av一区二区三区| 久久久久久有精品国产| 亚洲精品老司机| 久色婷婷小香蕉久久| 免费不卡视频| 国产精品99久久久久久久久 | 欧美特黄a级高清免费大片a级| 亚洲欧美文学| 欧美xx69| 欧美视频导航| 亚洲综合丁香| 久久精品在线| 国产日韩在线视频| 亚洲国内精品| 伊大人香蕉综合8在线视| 亚洲国产精品视频一区| 国内揄拍国内精品少妇国语| 在线亚洲一区二区| 日韩一区二区免费看| 日韩视频免费大全中文字幕| 99国产精品久久久| 欧美成人精品1314www| 久久精品国内一区二区三区| 欧美日韩免费一区二区三区| 免费美女久久99| 136国产福利精品导航| 欧美视频精品在线观看| 亚洲欧洲日本在线| 最新国产成人av网站网址麻豆| 欧美亚洲一区二区在线| 久久爱www| 国内精品久久国产| 久久夜色精品国产| 亚洲国产成人av| 一区二区av在线| 欧美va天堂| 一区二区电影免费在线观看| 亚洲女性裸体视频| 国模大胆一区二区三区| 免费中文字幕日韩欧美| 国产真实乱偷精品视频免| 久久精品综合一区| 亚洲愉拍自拍另类高清精品| 欧美色精品天天在线观看视频| 一本色道**综合亚洲精品蜜桃冫| 亚洲欧美激情在线视频| 国外成人性视频| 欧美四级在线| 欧美日韩免费精品| 老司机成人网| 久久riav二区三区| 在线午夜精品| 亚洲毛片在线看| 正在播放日韩| 亚洲黄页视频免费观看| 久久久久久有精品国产| 在线性视频日韩欧美| 亚洲激情亚洲| 亚洲欧洲日本国产| 欧美午夜在线视频| 欧美日韩免费一区| 欧美精品一二三| 美女精品在线观看| 久久久国产精彩视频美女艺术照福利| 洋洋av久久久久久久一区| 亚洲国产小视频在线观看| 欧美r片在线| 久久福利一区| 另类图片综合电影| 久久影视三级福利片| 久久亚洲精品欧美| 免费久久99精品国产| 欧美fxxxxxx另类| 91久久久久| 欧美一区日本一区韩国一区| 亚洲欧美综合v| 久久婷婷综合激情| 欧美巨乳在线观看| 国产精品网站在线观看| 狠狠色综合播放一区二区| 亚洲国产成人在线播放| 欧美在线一二三区| 久久激情婷婷| 欧美午夜精品久久久久久浪潮| 国产精品久久国产三级国电话系列 | 欧美精品日韩| 国产伦一区二区三区色一情| 国产一区二区在线免费观看| 亚洲高清久久久| 欧美在线免费一级片| 亚洲午夜精品福利| 欧美精品七区| 亚洲国产美国国产综合一区二区| 日韩午夜激情| 免费久久99精品国产自在现线| 99精品免费视频| 一区免费观看视频| 午夜亚洲福利| 亚洲激情一区二区| 亚洲欧美成人网| 国产精品播放| 性欧美精品高清| 亚洲尤物精选| 国产精品一区二区久久| 99精品欧美一区二区三区综合在线| 99精品欧美一区二区三区| 一区二区欧美日韩视频| 欧美另类变人与禽xxxxx| 国内精品国语自产拍在线观看| 久久精品日产第一区二区| 香蕉久久精品日日躁夜夜躁| 欧美性一区二区| 亚洲午夜久久久久久久久电影网| 免费成人av在线| 久久国产精品亚洲va麻豆| 国产精品麻豆欧美日韩ww | 午夜日韩在线观看| 亚洲精品视频在线观看免费| 欧美激情影院| 99热免费精品在线观看| 亚洲一区二区三区中文字幕在线| 国产精品视频| 另类图片综合电影| 国产精品video| 亚洲精品日韩激情在线电影| 国产亚洲一区精品| 久久久久成人精品| 欧美日韩黄视频| 日韩视频在线播放| 欧美.www| 免费成人av资源网| 国产欧美 在线欧美| 亚洲大片精品永久免费| 国产一区二区三区在线免费观看| 亚洲无吗在线| 在线亚洲高清视频| 欧美日韩成人综合在线一区二区|