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

首頁 > 學院 > 開發(fā)設計 > 正文

|算法討論|AC自動機 學習筆記

2019-11-11 04:58:40
字體:
來源:轉載
供稿:網(wǎng)友

在學習AC自動機之前需要熟練掌握WA自動機、RE自動機與TLE自動機

模板題:Hdu 2222 KeyWords Search,解決先給出關鍵字后,再給出尋找文本進行匹配問題

#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];//失配函數(shù) 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()//獲得失配函數(shù) { 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);
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 人禽l交免费视频 | 爱爱插插视频 | 国产精品久久久久久久久久妇女 | 国产成年人网站 | 91色综合综合热五月激情 | 国产成人观看 | 国产免费一区二区三区网站免费 | 午夜视频在线免费播放 | 视频一区二区三区中文字幕 | 精品一区二区免费视频视频 | 国产精品久久久久久久久久尿 | 爱看久久 | 欧美一级电影网 | 在线成人一区二区 | 国产99视频精品免视看9 | 高清中文字幕在线 | 成人国产精品一区二区毛片在线 | 色97在线| 国产手机av在线 | 亚洲精品自在在线观看 | 最新福利在线 | 欧美日韩亚洲另类 | 涩涩屋av | 国产流白浆高潮在线观看 | 国产精品一品二区三区四区18 | 亚洲射情| 在线观看美女av | 中文字幕精品在线播放 | 国产精品一区二区日韩 | 97超级碰碰人国产在线观看 | 精品国产一区二区三区免费 | 日本黄色a视频 | 国产亚洲自拍一区 | 中文字幕欧美在线 | 777sesese| 欧美成人一二三区 | 香蕉视频99| 3344永久免费 | 深夜影院一级毛片 | 国产一区二区三区黄 | 免费小毛片 |