麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

|Hdu 2222|AC自動機|Keywords Search

2019-11-11 04:59:18
字體:
來源:轉載
供稿:網友

Hdu傳送門 AC自動機模板題,注意重復關鍵字的處理

#include<cstdio> #include<algorithm> #include<cstring> #include<queue> #define ms(i,j) memset(i,j, sizeof i); using namespace std;const int MAXN = 10000 + 5, _SIZE = 26; int n;struct acam{ int sz;//結點編號 int res; int ch[MAXN*51][_SIZE];//Tire int last[MAXN*51];//后綴鏈接 int f[MAXN*51];//失配函數 int val[MAXN*51][2];//結點的權值 bool used[MAXN*51];//用過 void init()//初始化 { ms(val,0); ms(ch,0); ms(used,false); sz = 1; res = 0; } void insert(char *s, int v)//插入一個模板 { int u = 0; int len = strlen(s); for (int i=0;i<len;i++) { int c = s[i] - 'a'; if (ch[u][c]) { u = ch[u][c]; } else { ch[u][c] = ++sz; u = ch[u][c]; } if (i==len-1) { val[u][0] = v; val[u][1]++; } } } void g(int j)//遞歸更新cnt { if (j&&!used[val[j][0]]) { res+=val[j][1]; used[val[j][0]] = true; g(last[j]); } } void find(char *T)//在T中匹配 { int len = strlen(T); int j = 0; for (int i=0;i<len;i++) { int c = T[i] - 'a'; j = ch[j][c]; if (val[j][0]) g(j); else if (last[j]) g(last[j]); } } void getFail()//獲得失配函數 { queue<int> q; f[0] = 0; for (int c=0;c<_SIZE;c++)//初始化進隊 { int u = ch[0][c]; if (u) { q.push(u); f[u] = 0; last[u] = 0; } } while (!q.empty()) { int r = q.front(); q.pop(); for (int c=0;c<_SIZE;c++) { int u = ch[r][c]; if (!u) { ch[r][c] = ch[f[r]][c]; continue; } q.push(u); int j = f[r]; while (j&&!ch[j][c]) j = f[j]; f[u] = ch[j][c]; last[u] = (val[f[u]][0]) ? (f[u]) : (last[f[u]]); } } } }ac;char s[1000000 + 5];int main() { int kase; scanf("%d", &kase); while (kase--) { ac.init(); scanf("%d", &n); for (int i=1;i<=n;i++) { scanf("%s", s); ac.insert(s,i); } scanf("%s", s); ac.getFail(); ac.find(s);
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 免费观看黄色一级视频 | 18欧美性xxxx极品hd | 亚洲码无人客一区二区三区 | 亚洲成人第一页 | 日本中文字幕网址 | 国产亚洲精品久久久久久久久 | 91网站在线播放 | 精品人伦一区二区三区蜜桃网站 | 国产1区2区在线观看 | 91成人久久 | 成人av一二三区 | 免费毛片免费看 | 中国免费黄色 | 日韩视频在线观看免费 | 一区二区三区欧美在线观看 | 久章草在线视频 | 精品国产九九九 | 九九热视频这里只有精品 | 黄色99视频 | 国产精品午夜在线观看 | 污黄视频在线播放 | 欧美一级特级 | 久久久在线 | 久草手机在线 | 双性精h调教灌尿打屁股的文案 | 鲁人人人鲁人人鲁精品 | 国产精品一区在线看 | 国产精品v片在线观看不卡 成人一区二区三区在线 | 一级黄色国产视频 | 爽爽淫人综合网网站 | 精品国产一区二区三区在线观看 | 在线播放av网址 | 人人做人人看 | 19禁国产精品福利视频 | 亚洲性生活免费视频 | 久久精品a一级国产免视看成人 | 久久超碰99| 婷婷亚洲一区二区三区 | 一区国产视频 | 中国字幕av| 日本一级黄色大片 |