Aho-Corasick automaton 模板

typedef struct Node* node;const int MAXNs = ;//模式串最大長度 
const int MAXNS = ;//文章(待匹配串)最大長度 struct Node{node next[26];node fail;//失配指針int sum;Node(){sum = 0;fail = NULL;memset(next,NULL,sizeof next);}
};char s[MAXNs];//模式串void Insert(node root)//字典樹的建立
{node p = root;int len = strlen(s);for(int i=0 ; i<len ; ++i){int x = s[i] - 'a';if(p->next[x] == NULL){node newnode = new Node();p->next[x] = newnode;}p = p->next[x];}p->sum++;
}void build_fail_pointer(node root)//構造fail指針
{queue<node> Q;Q.push(root);node p,temp;while(!Q.empty()){temp = Q.front();Q.pop();for(int i=0 ; i<26 ; ++i){if(temp->next[i]){if(temp == root){temp->next[i]->fail = root;}else{p = temp->fail;while(p){if(p->next[i]){temp->next[i]->fail = p->next[i];break;}p = p->fail;}if(p == NULL) temp->next[i]->fail = root;}Q.push(temp->next[i]);}}}
}char S[MAXNS];//文章(待匹配串)int ac_automation(node root)//利用fail指針進行匹配。
{node p = root;int len = strlen(S);int ans = 0;for(int i=0 ; i<len ; ++i){int x = S[i] - 'a';while(!p->next[x] && p != root) p = p->fail;p = p->next[x];if(!p) p = root;node temp = p;while(temp != root){if(temp->sum >= 0){ans += temp->sum;temp->sum = -1;}else break;temp = temp->fail;}}return ans;
}void Del(node root){for(int i=0 ; i<26 ; ++i){if(root->next[i])Del(root->next[i]);}delete(root);
}int main(){int T;// case數量 scanf("%d",&T);while(T--){int N;//模式串數量 node root = new Node();scanf("%d",&N);while(N--){scanf("%s",s);Insert(root);}scanf("%s",S);build_fail_pointer(root);//構造fail指針printf("%d\n",ac_automation(root));Del(root);}return 0;
}

?

轉載于:https://www.cnblogs.com/vocaloid01/p/9514016.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/397282.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/397282.shtml
英文地址,請注明出處:http://en.pswp.cn/news/397282.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Ubuntu Server 14.04 下root無法ssh登陸

今天安裝了Ubuntu Server 14.04 在終端配置了root密碼后&#xff0c;使用SecureCRT和putty竟然不能ssh登陸&#xff0c;SecureCRT一直提示密碼不對&#xff0c;但是可以肯定輸入的密碼100%正確&#xff0c;用putty則一直報Access Denied&#xff0c;所以可以肯定系統限制了ro…

計算機的控制面板打不開,控制面板打不開,教您控制面板打不開怎么辦

最近有些不少的小伙伴向小編反映說&#xff0c;控制面板突然出現了打不開的情況&#xff0c;那么遇到這種情況該怎么辦呢&#xff1f;其實控制面板打不開很有可能是因為系統文件損壞造成的。今天&#xff0c;小編就來把打不開控制面板的解決方法分享給你們。其實控制面板是我們…

【算法題】Multiples of 3 and 5

Multiples of 3 and 5 原題 題意如下&#xff1a; 找出N以內的3和5的倍數的和。 思路 1、剛看到覺得好弱智&#xff0c;直接遍歷一遍不就OK了嗎&#xff1f;但是第2和第3個測試用例報了TLE&#xff0c;超時。 2、然后想不出來了&#xff0c;搜了一下&#xff0c;發現有一個類似…

PIL簡單圖片處理(上)

自己看了下python&#xff0c;本來想照教程上一點一點學的&#xff0c;學了一會發現好沒勁&#xff08;教程本身質量很好&#xff09;&#xff0c;學python就是為了好玩&#xff0c;為什么還這么按部就班勒&#xff1f;果斷google下python的爬蟲&#xff08;開始目的是這個&…

方舟服務器制作修改,ARK方舟:生存進化服務器禁止物品制造的修改方法

ARK方舟:生存進化服務器禁止物品制造的修改方法代碼對應的文件目錄:文件:Game.ini框架:[/script/shootergame.shootergamemode]例如禁用C4遙控器代碼為:ConfigOverrideItemCraftingCosts(ItemClassString"PrimalItem_WeaponC4_C",BaseCraftingResourceRequirements((…

Java中ArrayList的使用

ArrayList類是一個特殊的數組--動態數組。來自于System.Collections命名空間&#xff1b;通過添加和刪除元素&#xff0c;就可以動態改變數組的長度。 優點&#xff1a; 1、支持自動改變大小 2、可以靈活的插入元素 3、可以靈活的刪除元素 局限&#xff1a; 比一般的數組的速度…

mallco動態分配_malloc動態分配的內存的生存周期是多少?

曾經有一個朋友提過這樣一個問題&#xff0c;malloc動態分配的內存的生存周期是多少當時直接回答&#xff0c;當然是在調用free進行釋放之前阿!!但回頭我仔細想過這個問題&#xff0c;在free調用之前那段范圍內&#xff0c;但free只有一個指針參數&#xff0c;它是如何知道要釋…

中興中心管理服務器fxh3120,中興多媒體業務中心ZXMS80

運營支撐層&#xff1a; 提供面向視訊用戶的客服中心和面向管理員的業務中心、網管中心。客服中心提供會議預約、會議控制、帳單查詢、意見反饋等功能。業務中心分為業務受理中心、業務管理中心、認證計費中心。其中業務受理中心實現開戶、放號及收費等功能&#xff1b;業務管理…

隨機森林經典文

原文鏈接 轉載于:https://www.cnblogs.com/luoganttcc/p/10525324.html

python namespace unique_Python使用uuid庫生成唯一標識ID

uuid是128位的全局唯一標識符(univeral unique identifier)&#xff0c;通常用32位的一個字符串的形式來表現。有時也稱guid(globalunique identifier)。python中自帶了uuid模塊來進行uuid的生成和管理工作。python中的uuid模塊基于信息如MAC地址、時間戳、命名空間、隨機數、偽…

SQL Server 2008空間數據應用系列四:基礎空間對象與函數應用

SQL Server 2008空間數據應用系列四&#xff1a;基礎空間對象與函數應用 原文:SQL Server 2008空間數據應用系列四&#xff1a;基礎空間對象與函數應用友情提示&#xff0c;您閱讀本篇博文的先決條件如下&#xff1a; 1、本文示例基于Microsoft SQL Server 2008 R2調測。 2、具…

HBase-1.2.4LruBlockCache實現分析(一)

一、簡介 BlockCache是HBase中的一個重要特性&#xff0c;相比于寫數據時緩存為Memstore&#xff0c;讀數據時的緩存則為BlockCache。 LruBlockCache是HBase中BlockCache的默認實現&#xff0c;它采用嚴格的LRU算法來淘汰Block。 二、緩存級別 目前有三種緩存級別&#xf…

c .net ajax,Asp.net mvc 2中使用Ajax的三種方式

在Asp.net MVC中&#xff0c;我們能非常方便的使用Ajax。這篇文章將介紹三種Ajax使用的方式&#xff0c;分別為原始的Ajax調用、Jquery、Ajax Helper。分別采用這三種方式結合asp.net mvc去實現一個史上最簡單的留言板。首先看一下原始的Ajax的調用的:定義CommentController&am…

爆款AR游戲如何打造?網易楊鵬以《悠夢》為例詳解前沿技術

本文來自網易云社區。 7月31日&#xff0c;2018云創大會游戲論壇在杭州國際博覽中心103B圓滿舉行。本場游戲論壇聚焦探討了可能對游戲行業發展有重大推動的新技術、新實踐&#xff0c;如AR、區塊鏈、安全、大數據等。 網易AR游戲生態合作負責人楊鵬表示&#xff0c;傳統游戲模式…

景深決定照相機什么特性_照相機光圈與景深的關系

展開全部「光圈」&#xff0c;光圈是一個用來控制光線透過鏡頭&#xff0c;進入機身636f70793231313335323631343130323136353331333264663664內感光面的光量的裝置&#xff0c;它通常是在鏡頭內。表達光圈大小我們是用f值。光圈f值鏡頭的焦距/鏡頭口徑的直徑從以上的公式可知要…

潤乾V4導出TXT時自定義分隔符

&#xfeff;&#xfeff;◆ 背景說明 報表中&#xff0c;導出text時&#xff0c;默認沒有分隔符&#xff1b;應用中對導出Text&#xff0c;希望能自定義分隔符。在tag中定義了 textDataSeparator屬性&#xff0c;讓用戶在導出Text時自定義分隔符&#xff0c;從而確保滿足應用…

Spark學習體會

在去年圖計算工作中&#xff0c;和公司里實習的博士生嘗試過Spark后&#xff0c;發現Spark比Hadoop在計算速度上后很大的提高。Spark的計算使用Scala語言編寫代碼&#xff0c;其中圖計算用到了GraphX。對Spark技術的學習已經非常重要。 最近半年多時間里&#xff0c;經常看…

fastadmin自定義按鈕不是ajax,Fastadmin 自定義按鈕實現審核功能

功能描述新增自定義審核按鈕&#xff0c;點擊審核按鈕后&#xff0c;按鈕變為取消審核按鈕&#xff0c;同理點擊取消審核按鈕后&#xff0c;按鈕變為審核按鈕實現功能如下圖微信圖片_20200827112914.png上代碼{field: operate, title: __(Operate), table: table, events: Tabl…

函數的命名空間以及作用域

轉載于:https://www.cnblogs.com/mpfei/p/9451208.html

python獲取路由器數據包pppoe_PPPoE協議***4:如何得到PPPoE服務器的mac地址

在局域網中&#xff0c;怎樣得到PPPoE服務器的mac地址是一件頭疼的事情&#xff0c;特別是在windows環境下&#xff1b;得到PPPoE服務器mac地址的實現方法有兩種&#xff1a;1.在windows下&#xff0c;我們運行wireshark軟件&#xff0c;可以得到所有進出網卡的數據包格式和內容…