日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

2017西安交大ACM小学期 神器插座 KMP匹配

發(fā)布時間:2023/12/3 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2017西安交大ACM小学期 神器插座 KMP匹配 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

神奇插座

發(fā)布時間: 2017年7月3日 11:27?? 最后更新: 2017年7月5日 13:46?? 時間限制: 500ms?? 內(nèi)存限制: 128M

描述

AA所在的國家有一項神奇的發(fā)明:插座。這里的插座不僅有兩孔、三孔,而是有多種形態(tài),下面用不同的小寫字母表示不同的插座。插線板可以看做一排插座,因而下面用小寫字母組成的字符串表示插線板。

該國家的用電器的插頭也很特別,是由一串插頭固定在一起的,下面用大寫字母組成的字符串表示。只有插座和插頭匹配,該用電器才能插在插線板上。例如:

插頭ABCBA可以插在插線板abcbabcba上。

現(xiàn)在問題來了:給定插線板和插頭,問該插線板上最多能插幾個這樣的插頭?注意,這些插頭不能重疊。

輸入

多組測試數(shù)據(jù)。
每組測試數(shù)據(jù)包含兩行,第一行為插座,第二行為插頭。
插座、插頭對應(yīng)的字符均不超過106
總數(shù)據(jù)量不超過107個字符。

輸出

對每組數(shù)據(jù),輸出一行一個整數(shù),表示答案。

樣例輸入1?復(fù)制 abcbabcba ABCBA 樣例輸出1 1 解法非常簡單,直接進(jìn)行KMP匹配就可以了,但是KMP的模板要有一個小小的改動(因為這里題目要求插頭不能重疊),那就是只要匹配到一個插頭以后,直接置j = 0

這樣可以避過重疊

代碼:

#include <iostream> #include <cstdio> using namespace std; #define MAXN 2000001 char s[MAXN]; char str[MAXN]; int fail[MAXN]; int search(char *str) {int ans = 0;for (int i = 0, j = 0; str[i]; i++){while (j && str[i] - 'a' != s[j] - 'A')j = fail[j - 1];if (str[i] - 'a' == s[j] - 'A' && !s[++j]){ans++;j=0;}}return ans; }void make_fail() {for (int i = 1, j = 0; s[i]; i++){while (j && s[i] != s[j])j = fail[j - 1];if (s[i] == s[j])fail[i] = ++j;else fail[i] = 0;} } int main(){while(~scanf("%s %s",str,s)){make_fail();printf("%d\n",search(str));}return 0; }




總結(jié)

以上是生活随笔為你收集整理的2017西安交大ACM小学期 神器插座 KMP匹配的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。