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

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>
            欧美一区亚洲一区| 久久精品1区| 亚洲一区自拍| 久久激情视频免费观看| 亚洲人在线视频| 亚洲经典视频在线观看| 亚洲精品九九| 日韩一区二区精品| 亚洲无毛电影| 欧美专区在线观看| 久久婷婷影院| 亚洲大片在线观看| 免费一级欧美在线大片| 亚洲精品老司机| 性欧美xxxx大乳国产app| 久久久www| 欧美日韩一区自拍| 国产亚洲女人久久久久毛片| 经典三级久久| 亚洲婷婷免费| 老司机aⅴ在线精品导航| 亚洲人成在线播放| 欧美在线日韩| 欧美视频不卡中文| 激情欧美一区二区三区| 99精品免费| 久久婷婷国产综合尤物精品 | 久久久五月天| 亚洲激情国产精品| 欧美亚洲一区二区三区| 欧美成人综合一区| 国产视频一区在线观看| 一区二区av| 欧美freesex8一10精品| 亚洲影音一区| 欧美精品入口| 亚洲成人资源| 久久精品国亚洲| 一本色道久久综合狠狠躁篇怎么玩 | 米奇777在线欧美播放| 国产精品久久久久秋霞鲁丝| 亚洲激情午夜| 另类激情亚洲| 欧美一区二区三区在线| 国产精品久久久久久久9999| 亚洲美女中文字幕| 欧美成人精品在线观看| 欧美资源在线| 国产一区二区三区奇米久涩| 亚洲欧美三级在线| 亚洲精品一区二区三区在线观看| 久久久久在线观看| 国产日韩久久| 性欧美videos另类喷潮| 中文精品视频一区二区在线观看| 久久精品国产成人| 在线亚洲自拍| 欧美日韩精品国产| 日韩视频免费在线| 欧美国产激情二区三区| 欧美在线亚洲| 国内成人自拍视频| 久久精品在线免费观看| 香蕉久久夜色精品国产使用方法 | 麻豆精品一区二区av白丝在线| 国产日本欧美在线观看| 午夜精品一区二区三区在线视| 99热在线精品观看| 国产精品电影网站| 性欧美video另类hd性玩具| 国产精品99久久不卡二区| 欧美网站大全在线观看| 亚洲综合不卡| 亚洲欧美在线高清| 国内精品久久久久国产盗摄免费观看完整版| 香蕉av福利精品导航| 欧美亚洲日本国产| 在线免费不卡视频| 亚洲激情一区二区| 国产精品美女主播| 久久精品男女| 女仆av观看一区| 亚洲线精品一区二区三区八戒| 亚洲婷婷综合久久一本伊一区| 国产视频在线观看一区二区| 男女激情久久| 欧美剧在线免费观看网站| 亚洲一区在线观看视频| 欧美一区不卡| 日韩一级免费| 欧美在线视频全部完| 亚洲欧洲在线一区| 亚洲一区二区不卡免费| 在线看片成人| 亚洲综合日韩在线| 91久久精品日日躁夜夜躁国产| 亚洲最新视频在线| 国产综合久久久久久鬼色| 亚洲国产美女久久久久| 国产精品自拍一区| 亚洲黄色尤物视频| 国产亚洲aⅴaaaaaa毛片| 亚洲国产精品久久91精品| 国产日韩精品一区二区浪潮av| 亚洲电影免费在线观看| 国产日韩一区二区三区在线| 亚洲人永久免费| 怡红院精品视频| 亚洲综合视频1区| aaa亚洲精品一二三区| 久久国产精品久久w女人spa| 亚洲图片在线观看| 欧美mv日韩mv国产网站app| 欧美在线free| 国产精品久久久久久福利一牛影视| 亚洲电影av| 亚洲欧美国产另类| 久久亚洲国产精品一区二区 | 欧美成黄导航| 欧美制服丝袜| 国产精品久久久久久久午夜 | 国产亚洲精品aa| 亚洲乱码国产乱码精品精天堂| 精品不卡一区| 亚洲制服av| 一区二区三区黄色| 美女91精品| 蜜桃久久av| 国产在线乱码一区二区三区| 亚洲图片在区色| 亚洲中字在线| 国产精品wwwwww| 一区二区三区欧美亚洲| 亚洲午夜精品一区二区三区他趣| 牛夜精品久久久久久久99黑人| 麻豆精品网站| 亚洲福利专区| 欧美**人妖| 亚洲国产精品久久久久秋霞不卡| 伊人久久婷婷| 毛片一区二区三区| 男男成人高潮片免费网站| 亚洲国产精品999| 欧美a级片网| 亚洲日本电影在线| 一区二区三区欧美成人| 欧美视频中文在线看 | 激情文学一区| 久久天天综合| 亚洲国产99| 中文国产一区| 国产女主播一区二区三区| 欧美在线免费看| 欧美国产亚洲视频| 日韩视频中文字幕| 欧美午夜精品理论片a级大开眼界| 中文国产成人精品久久一| 欧美一区二区视频免费观看 | 午夜国产不卡在线观看视频| 国产精品亚发布| 久久精品中文字幕一区| 亚洲电影免费观看高清完整版在线观看 | 欧美大胆a视频| 亚洲美女少妇无套啪啪呻吟| 国产精品h在线观看| 欧美一区深夜视频| 亚洲区欧美区| 久久精品免费看| 亚洲理伦在线| 国产一级精品aaaaa看| 欧美成人午夜影院| 亚洲在线观看视频网站| 国外成人在线视频| 一本久道久久综合狠狠爱| 欧美一区在线直播| 亚洲高清一区二区三区| 欧美视频一区二区在线观看| 久久精品女人| 一区电影在线观看| 免费视频久久| 午夜精品久久久久久99热| 在线播放一区| 国产精品人成在线观看免费| 久久综合色一综合色88| 中文在线一区| 亚洲日本精品国产第一区| 久久久女女女女999久久| av成人免费在线| 樱桃视频在线观看一区| 国产精品视频一区二区高潮| 欧美激情精品| 久久精品中文字幕一区| 亚洲一区精彩视频| 亚洲茄子视频| 欧美电影免费观看高清| 欧美在线在线| 久久av一区二区| 午夜精品久久久久影视| 日韩视频免费大全中文字幕| 一区二区三区在线看|