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

coreBugZJ

此 blog 已棄。

Keywords Search,HDOJ 2222

Keywords Search

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)

Problem Description
In the modern time, Search engine came into the life of everybody like Google, Baidu, etc.
Wiskey also wants to bring this feature to his image retrieval system.
Every image have a long description, when users type some keywords to find the image, the system will match the keywords with description of image and show the image which the most keywords be matched.
To simplify the problem, giving you a description of image, and some keywords, you should tell me how many keywords will be match.
 

Input
First line will contain one integer means how many cases will follow by.
Each case will contain two integers N means the number of keywords and N keywords follow. (N <= 10000)
Each keyword will only contains characters 'a'-'z', and the length will be not longer than 50.
The last line is the description, and the length will be not longer than 1000000.
 

Output
Print how many keywords are contained in the description.
 

Sample Input
1
5
she
he
say
shr
her
yasherhs
 

Sample Output
3


AC 自動機

我的代碼:

  1 #include <iostream>
  2 #include <cstdio>
  3 
  4 using namespace std;
  5 
  6 const int ACTC = 26;
  7 const int ACTM = 800000;
  8 const int ACQL = 800000;
  9 
 10 struct AC
 11 {
 12         int count;
 13         AC * fail;
 14         AC * ch[ ACTC ];
 15 };
 16 
 17 AC * que[ ACQL ];
 18 
 19 AC * ac_new( bool init = false ) {
 20         int i;
 21         AC * p;
 22         static AC memAC[ ACTM ];
 23         static int tot = 0;
 24         if ( init ) {
 25                 tot = 0;
 26                 return 0;
 27         }
 28         p = memAC + tot++;
 29         p->count = 0;
 30         p->fail  = 0;
 31         for ( i = 0; i < ACTC; ++i )
 32                 p->ch[ i ] = 0;
 33         return p;
 34 }
 35 
 36 int ac_add( AC * & root, const char * first, const char * last ) {
 37         AC ** p = &root;
 38         for ( ; ; ) {
 39                 if ( *== 0 ) *= ac_new();
 40                 if ( first == last ) return ++( (*p)->count );
 41                 p = &( (*p)->ch[ *first++ ] );
 42         }
 43 }
 44 
 45 void ac_build( AC * root ) {
 46         // root != 0
 47         int qh = 0, qt = 1, i;
 48         AC *pf, *pc, *pt;
 49         root->fail = 0;
 50         que[ 0 ] = root;
 51         while ( qh != qt ) {
 52                 pf = que[ qh ];
 53                 qh = ( qh + 1  ) % ACQL;
 54                 for ( i = 0; i < ACTC; ++i ) {
 55                         if ( pc = pf->ch[ i ] ) {
 56                                 for ( pt = pf->fail; pt && ( pt->ch[ i ] == 0 ); pt = pt->fail )
 57                                         ;
 58                                 pc->fail = pt ? pt->ch[ i ] : root;
 59                                 que[ qt ] = pc;
 60                                 qt = ( qt + 1 ) % ACQL;
 61                         }
 62                 }
 63         }
 64 }
 65 
 66 int ac_query( AC * root, const char * first, const char * last ) {
 67         // root != 0
 68         int ans = 0;
 69         AC *= root, *q;
 70         while ( first != last ) {
 71                 while ( p && ( p->ch[ *first ] == 0 ) ) {
 72                         p = p->fail;
 73                 }
 74                 if ( p ) {
 75                         q = p = p->ch[ *first++ ];
 76                         while ( q && ( q->count != -1 ) ) {
 77                                 ans += q->count;
 78                                 q->count = -1;
 79                                 q = q->fail;
 80                         }
 81                 }
 82                 else {
 83                         p = root;
 84                         ++first;
 85                 }
 86         }
 87         return ans;
 88 }
 89 
 90 char txt[ 1000009 ], pat[ 70 ];
 91 AC * root;
 92 
 93 int main() {
 94         int td, n;
 95         char * pc;
 96         scanf( "%d"&td );
 97         while ( td-- ) {
 98                 scanf( "%d%*c"&n );
 99                 ac_new( true );
100                 root = 0;
101                 while ( n-- ) {
102                         gets( pat );
103                         for ( pc = pat; *pc; ++pc )
104                                 *pc -= 'a';
105                         ac_add( root, pat, pc );
106                 }
107                 gets( txt );
108                 for ( pc = txt; *pc; ++pc )
109                         *pc -= 'a';
110                 ac_build( root );
111                 printf( "%d\n", ac_query( root, txt, pc ) );
112         }
113         return 0;
114 }
115 


posted on 2011-03-25 17:34 coreBugZJ 閱讀(467) 評論(0)  編輯 收藏 引用 所屬分類: ACM

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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在线精品视频| 一区二区三区国产| 国产精品久久网| 久久精品欧美| 蜜桃精品久久久久久久免费影院| 亚洲乱码国产乱码精品精| 亚洲精品一区二区在线| 国产精品热久久久久夜色精品三区 | 亚洲免费黄色| 国产精品久久久久久久电影| 久久久精品国产免费观看同学| 久久久91精品国产| 亚洲人成绝费网站色www| 日韩视频在线播放| 国产婷婷色一区二区三区在线| 美国十次了思思久久精品导航| 欧美久久成人| 久久久精品动漫| 欧美精品一级| 久久亚洲综合色一区二区三区| 欧美大片在线影院| 欧美一区二区国产| 久久亚洲一区二区三区四区| 亚洲午夜久久久| 久久久久久久久综合| 中文欧美日韩| 久久视频国产精品免费视频在线| 99视频在线观看一区三区| 欧美在线视频网站| 亚洲桃色在线一区| 久久久精品国产免大香伊| 在线亚洲一区| 久久综合九色九九| 欧美一二区视频| 欧美精品久久天天躁| 久久久久成人精品| 欧美日韩在线另类| 欧美电影免费网站| 黑人巨大精品欧美黑白配亚洲| 日韩一区二区久久| 亚洲另类在线视频| 久久先锋资源| 久久人人爽国产| 国产精品一区二区三区久久| 亚洲精品国偷自产在线99热| 狠狠综合久久| 欧美一二三区在线观看| 性色av一区二区三区在线观看| 欧美精品国产| 亚洲国产三级网| 在线观看亚洲a| 欧美一区二区三区日韩| 欧美一级专区| 国产精品视频免费观看| 在线午夜精品| 亚洲制服欧美中文字幕中文字幕| 欧美人与禽猛交乱配| 亚洲国产日韩欧美在线99| 最新69国产成人精品视频免费| 久久精品国产综合精品| 久久九九国产精品怡红院| 国产乱码精品一区二区三区忘忧草| 亚洲视频1区| 午夜在线成人av| 国产精品美女久久久浪潮软件 | 久久综合一区二区| 国产美女扒开尿口久久久| 亚洲夜间福利| 欧美中文字幕在线播放| 国产日韩欧美自拍| 久久精品国产一区二区三区免费看 | 亚洲美女视频在线免费观看| 欧美激情精品久久久久久免费印度| 亚洲二区在线视频| 一区二区三区四区五区精品视频 | 欧美午夜片在线观看| 亚洲视频在线二区| 欧美在线啊v一区| 一区二区三区在线不卡| 免费久久99精品国产自| 亚洲欧洲在线看| 亚洲欧美日韩天堂一区二区| 国产一区二区精品久久99| 久久久久久网| 亚洲精品一级| 欧美一区二区三区视频| 怡红院av一区二区三区| 欧美日韩日本国产亚洲在线 | 亚洲国产成人av好男人在线观看| 99热在这里有精品免费| 国产精品免费看久久久香蕉| 久久国产夜色精品鲁鲁99| 亚洲国产精品日韩| 亚洲欧美日韩综合| 亚洲高清色综合| 国产精品大片| 另类激情亚洲| av成人免费观看| 老司机免费视频一区二区| aa级大片欧美| 极品尤物一区二区三区| 欧美日韩国产色视频| 久久精品视频在线播放| 日韩小视频在线观看专区| 久久综合99re88久久爱| 亚洲一区激情| 亚洲欧洲在线看| 国产亚洲人成网站在线观看| 欧美全黄视频| 美女精品在线| 午夜久久影院| 一区二区三区免费在线观看| 欧美激情亚洲综合一区| 久久成人免费视频| 亚洲一二三区精品| 最新成人av在线| 国内外成人在线| 国产精品一级久久久| 欧美精品aa| 美女国产一区| 久久久免费精品| 久久狠狠久久综合桃花| 午夜精品久久久久久久久久久久| 亚洲精品欧洲精品| 亚洲大胆av| 老司机精品视频一区二区三区| 欧美一区二区三区另类| 亚洲午夜精品一区二区| 一区二区精品国产| 亚洲狼人精品一区二区三区| 在线成人激情黄色| 激情五月***国产精品| 国产中文一区| 国产亚洲欧美激情| 国产亚洲精品aa午夜观看| 欧美性猛交视频| 欧美四级伦理在线| 欧美日韩国产系列| 欧美日韩三级| 欧美三级不卡| 国产精品扒开腿做爽爽爽视频| 欧美三区在线| 国产精品永久免费| 国产视频欧美视频| 国产日韩亚洲欧美| 狠狠色丁香婷婷综合| 一色屋精品视频在线观看网站| 在线观看视频一区二区| 亚洲欧洲一区二区在线播放| 亚洲精品专区| 亚洲专区免费| 欧美一区二区三区免费在线看| 欧美一区二区在线看| 久久久7777| 欧美高清在线一区| 亚洲精品免费在线观看| 日韩一区二区精品在线观看| 亚洲影院在线观看| 久久精品国语| 欧美激情一区二区三区不卡| 国产精品jizz在线观看美国 | 亚洲国产日韩欧美在线99| 最新国产拍偷乱拍精品| 99视频一区二区三区| 欧美一区二区视频97| 美女国产一区| 一本久道综合久久精品| 欧美一区二区观看视频| 免费一区二区三区| 国产精品美女久久久久av超清| 国产在线精品一区二区夜色| 亚洲日本中文字幕| 欧美一级淫片aaaaaaa视频| 理论片一区二区在线| 亚洲美女啪啪| 久久久久久穴| 国产精品高潮久久| 在线视频国产日韩| 在线亚洲伦理| 欧美二区在线观看| 亚洲免费伊人电影在线观看av| 免费观看日韩av| 国产精品永久| 亚洲视频第一页| 欧美大片在线看免费观看| 国产精品99久久久久久宅男 | 久久国产精品电影| 欧美日韩视频在线| 亚洲高清不卡在线观看| 久久国产精品久久久| 亚洲美女区一区| 麻豆成人小视频| 国产在线精品成人一区二区三区 | 国产综合色在线视频区| 一区二区三区视频在线看|