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

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 閱讀(460) 評論(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>
            国产欧美精品日韩精品| 欧美高清视频一区二区| 国产精品一区毛片| 午夜在线精品| 久久精品国产第一区二区三区最新章节 | 欧美不卡三区| 日韩午夜激情| 亚洲一区视频在线观看视频| 狠狠色狠狠色综合| 亚洲风情在线资源站| 欧美成人午夜影院| 午夜精品美女久久久久av福利| 欧美在线免费视频| 亚洲精品久久视频| 亚洲一区综合| 亚洲电影免费观看高清完整版在线| 亚洲国产影院| 国产午夜精品久久久| 亚洲高清视频在线| 国产精品嫩草影院av蜜臀| 乱码第一页成人| 欧美日韩一区二区在线视频| 久久久久久久网站| 欧美日韩一级片在线观看| 久久精品日韩| 欧美日韩国产精品一区| 久久久久这里只有精品| 欧美日韩国产一中文字不卡| 久久久久国产免费免费| 欧美日韩国产天堂| 麻豆国产va免费精品高清在线| 欧美日韩精品欧美日韩精品 | 亚洲日本va在线观看| 亚洲专区在线| 宅男噜噜噜66国产日韩在线观看| 久久激情综合| 欧美一区二区高清| 欧美日韩亚洲一区二区三区在线 | 久久午夜羞羞影院免费观看| 欧美视频官网| 亚洲国产精品一区二区第四页av| 国产一区二区三区电影在线观看| 亚洲免费电影在线| 亚洲激情综合| 久久青青草综合| 久久久久五月天| 国产三级欧美三级| 亚洲免费影视第一页| 亚洲在线成人精品| 欧美日韩国产成人高清视频| 欧美激情导航| 亚洲黄色一区| 免费在线亚洲| 亚洲国产精品黑人久久久 | 国产日韩综合| 亚洲欧美视频在线观看| 午夜一区二区三区不卡视频| 国产精品不卡在线| 在线亚洲激情| 欧美一区1区三区3区公司| 国产精品久久久久77777| 亚洲精品免费观看| 一区二区三区久久网| 欧美精品一区二区三区在线看午夜| 欧美国产精品中文字幕| 最新亚洲激情| 欧美精品免费观看二区| 一区二区三区日韩精品| 亚洲自拍偷拍福利| 国产精品揄拍500视频| 午夜伦理片一区| 久久这里有精品视频| 亚洲国产精品va在线看黑人| 欧美高清视频| 在线综合亚洲欧美在线视频| 欧美亚洲系列| 国产一区二区三区久久| 久久午夜精品| 99精品欧美一区二区蜜桃免费| 亚洲一区日本| 国产自产v一区二区三区c| 六月婷婷久久| 一区二区三区四区五区在线| 久久丁香综合五月国产三级网站| 国产一区 二区 三区一级| 久久久精品一区| 亚洲精品免费一二三区| 亚洲欧美在线视频观看| 黄色成人精品网站| 欧美精品自拍| 先锋资源久久| 亚洲精品免费网站| 久久久青草青青国产亚洲免观| 亚洲国产精品ⅴa在线观看 | 欧美丰满少妇xxxbbb| 亚洲在线电影| 亚洲高清在线视频| 午夜国产一区| 99re成人精品视频| 国产婷婷97碰碰久久人人蜜臀| 免费美女久久99| 午夜精品在线观看| 亚洲毛片网站| 欧美va亚洲va日韩∨a综合色| 亚洲视频一二三| 在线观看欧美亚洲| 国产精品婷婷| 欧美激情中文不卡| 久久久精品午夜少妇| 亚洲在线一区| 亚洲精品一区二区三区樱花| 老司机免费视频一区二区| 亚洲影院免费| 日韩视频在线一区二区三区| 激情视频一区| 国产精品永久免费视频| 欧美视频一区二区在线观看| 男女激情久久| 久久精品99国产精品| 亚洲制服丝袜在线| 日韩一级大片| 亚洲精品久久久久久久久久久| 欧美成人免费在线视频| 久久久久久久激情视频| 香港久久久电影| 亚洲伊人网站| 亚洲午夜久久久久久久久电影院| 亚洲激情在线观看| 亚洲国产经典视频| 亚洲国产成人精品久久| 激情欧美一区二区三区| 国产综合色精品一区二区三区| 国产精品一区免费视频| 国产精品系列在线| 国产精品社区| 国产精品一二三四区| 国产精品永久免费在线| 国产美女精品视频| 国产午夜久久| 极品少妇一区二区三区精品视频| 国内精品视频一区| 国产亚洲精品7777| 国语自产在线不卡| 在线日本高清免费不卡| 在线播放不卡| 亚洲人成在线播放| 99精品欧美一区二区三区综合在线| 亚洲片区在线| 99在线精品免费视频九九视| 一区二区三区四区五区精品视频| 99这里有精品| 亚洲欧美影院| 另类av一区二区| 亚洲第一在线视频| 日韩一级二级三级| 亚洲一级二级| 久久国产精品久久久久久电车| 久久久精品一区二区三区| 狼狼综合久久久久综合网| 欧美激情精品久久久| 国产精品久久久久aaaa樱花| 国产欧美一区二区三区在线老狼| 合欧美一区二区三区| 亚洲日本成人女熟在线观看| 亚洲一区二区三区国产| 久久超碰97中文字幕| 欧美激情亚洲国产| 99一区二区| 久久亚洲精品一区二区| 欧美日本不卡高清| 国产精品日韩在线观看| 亚洲成色777777在线观看影院| 99精品福利视频| 久久成人免费| 亚洲欧洲午夜| 欧美在线视频一区| 欧美日韩国产大片| 伊大人香蕉综合8在线视| 一区二区高清| 久久久久一区二区| 一区二区欧美日韩| 久久婷婷国产综合尤物精品| 欧美肉体xxxx裸体137大胆| 在线观看一区二区视频| 亚洲无毛电影| 欧美好骚综合网| 午夜影院日韩| 国产精品成人久久久久| 亚洲国产精品嫩草影院| 欧美一乱一性一交一视频| 亚洲精品乱码久久久久久久久| 久久精品视频免费观看| 国产精品麻豆成人av电影艾秋| 亚洲精品一区二区三区樱花| 久久久91精品国产| 中日韩美女免费视频网址在线观看 | 欧美成人高清视频| 午夜一级久久| 国产精品一区=区| 一区二区三区不卡视频在线观看 |