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

pku 1816 wild words trie樹的活用

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

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

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

另外,這題建議用動態內存分配,我開始開了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 閱讀(284) 評論(0)  編輯 收藏 引用 所屬分類: search 、string algorithm

<2010年10月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

導航

統計

公告

統計系統

留言簿(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>
            中日韩美女免费视频网址在线观看| 久久99在线观看| 一本色道久久综合亚洲精品按摩 | 日韩午夜中文字幕| 国产一二精品视频| 国产欧美一级| 六月婷婷久久| 久久综合导航| 蜜桃视频一区| 亚洲性感激情| 午夜精品区一区二区三| 亚洲一区在线免费| 亚洲在线日韩| 午夜久久一区| 久久精品主播| 欧美激情按摩| 欧美日韩一区二区视频在线观看| 欧美日韩午夜激情| 蜜臀av性久久久久蜜臀aⅴ四虎| 麻豆精品视频在线观看视频| 久久综合福利| 欧美日本精品一区二区三区| 欧美人与禽性xxxxx杂性| 久久久久久999| 欧美成人高清视频| 欧美日本一区二区三区| 国产精品白丝黑袜喷水久久久| 国产精品va在线播放| 国产午夜精品美女视频明星a级| 国产午夜精品一区二区三区欧美 | 亚洲成人直播| 夜夜爽www精品| 亚洲精品乱码久久久久| 亚洲午夜小视频| 久久精品在线观看| 99av国产精品欲麻豆| 99精品久久免费看蜜臀剧情介绍| 亚洲人成小说网站色在线| 亚洲精品一品区二品区三品区| 亚洲综合电影| 老司机午夜免费精品视频| 欧美日韩久久久久久| 国产欧美日本一区视频| 亚洲高清视频中文字幕| 久久人人97超碰精品888| 亚洲视频 欧洲视频| 亚洲视频免费在线| 日韩午夜激情| 久久尤物视频| 国产日韩欧美一区在线| 一区二区高清视频在线观看| 欧美xx视频| 小黄鸭精品aⅴ导航网站入口| 欧美日韩一区二区视频在线观看| 亚洲高清电影| 久久这里只有| 玖玖在线精品| 亚洲国产一二三| 欧美成人免费在线| 久久精品成人一区二区三区蜜臀 | 亚洲免费一级电影| 亚洲黄网站黄| 欧美丰满高潮xxxx喷水动漫| 亚洲国产精品99久久久久久久久| 亚洲影院在线| 欧美日韩午夜在线视频| 国产精品欧美日韩一区| 亚洲综合二区| 亚洲无人区一区| 国产精品久久久久久久久免费 | 亚洲高清在线播放| 美国十次了思思久久精品导航| 久久岛国电影| 最新69国产成人精品视频免费| 欧美sm视频| 欧美精品一区二区三区久久久竹菊 | 亚洲精品美女久久久久| 欧美成人久久| 一本一本a久久| 亚洲在线免费| 亚洲国产精品123| 一本色道**综合亚洲精品蜜桃冫| 国产精品久久久久久久久久久久久久 | 欧美a级片网站| 欧美精品久久天天躁| 亚洲色诱最新| 久久av在线看| 99精品国产在热久久下载| 亚洲天堂免费观看| 一区二区视频免费完整版观看| 欧美成年人视频| 欧美日韩在线影院| 久久中文字幕一区| 欧美午夜宅男影院在线观看| 久久国产精品一区二区三区| 免费欧美电影| 久久久免费精品| 欧美日韩午夜在线视频| 久久久久久久久久久久久久一区| 免费久久99精品国产| 新狼窝色av性久久久久久| 免费日韩av片| 久久久亚洲欧洲日产国码αv | 久久精品中文字幕一区| 99国产精品| 久久久久.com| 欧美一区二区三区免费在线看| 欧美成人黑人xx视频免费观看| 欧美在线视频免费播放| 欧美福利电影在线观看| 久久综合九九| 久久精品免费播放| 亚洲欧洲精品一区二区三区波多野1战4| 亚洲免费激情| 亚洲美女免费精品视频在线观看| 欧美 日韩 国产精品免费观看| 久久久亚洲国产天美传媒修理工 | 久久午夜电影| 国产精品久久久久久久久久直播 | 国产精品手机视频| 久久婷婷丁香| 欧美色道久久88综合亚洲精品| 你懂的网址国产 欧美| 国产伦精品一区二区三区在线观看| 亚洲精品乱码久久久久久按摩观| 亚洲成人在线| 久久久久88色偷偷免费| 久久久久久夜| 国产亚洲一区二区三区在线观看 | 久久综合色播五月| 欧美一区二区在线观看| 国产精品视频999| 一区二区三区精品视频| 亚洲天堂av图片| 欧美视频精品在线观看| 99ri日韩精品视频| 在线视频你懂得一区二区三区| 欧美激情一区二区三级高清视频 | 亚洲人成在线影院| 亚洲精品在线免费| 欧美日本免费| 日韩一区二区电影网| 亚洲欧美日韩另类| 国产麻豆日韩| 欧美在线观看网址综合| 久久久亚洲高清| 91久久极品少妇xxxxⅹ软件| 欧美 日韩 国产一区二区在线视频 | 美女久久一区| 亚洲国产精品久久久久婷婷老年 | 亚洲国内高清视频| 一区二区三区日韩| 国产精品乱码一区二三区小蝌蚪| 亚洲国产成人在线| 欧美成人一品| 亚洲精品乱码久久久久久久久 | 亚洲欧美日韩精品在线| 国产欧美日韩高清| 久久gogo国模裸体人体| 免费成人av| 亚洲日韩欧美视频| 欧美日韩免费区域视频在线观看| 99精品热视频| 葵司免费一区二区三区四区五区| 亚洲欧洲日韩在线| 欧美视频一区二区三区四区| 亚洲在线视频一区| 久久中文字幕导航| 一区二区日本视频| 国产一区再线| 欧美激情久久久久| 亚洲视频 欧洲视频| 美女国产一区| 亚洲一区二区三区色| 国产拍揄自揄精品视频麻豆| 久久亚洲精品欧美| 这里只有精品视频在线| 欧美 亚欧 日韩视频在线| 99re成人精品视频| 国内精品久久久久影院色| 欧美日韩精品在线观看| 久久久91精品国产| 亚洲精选视频免费看| 久久久精品一区| 一区二区免费看| 揄拍成人国产精品视频| 欧美片第1页综合| 蜜桃av一区| 欧美一二三区精品| 亚洲美女视频网| 欧美成人高清| 欧美在线黄色| 亚洲一级黄色片| 亚洲美女免费精品视频在线观看| 国产一区二区剧情av在线| 欧美日韩亚洲91| 欧美成人免费小视频| 久久精品夜夜夜夜久久| 亚洲在线播放| 亚洲天堂av在线免费|