3708 Problem C 剪花布條

2021-08-25 22:12:08 字數 910 閱讀 8096

時間限制: 1000 sec  記憶體限制: 10000 mb

提交: 33  解決: 17

一塊花布條,裡面有些圖案,另有一塊直接可用的小飾條,裡面也有一些圖案。對於給定的花布條和小飾條,計算一下能從花布條中盡可能剪出幾塊小飾條來呢?

輸入中含有一些資料,分別是成對出現的花布條和小飾條,其布條都是用可見ascii字元表示的,可見的ascii字元有多少個,布條的花紋也有多少種花樣。花紋條和小飾條不會超過1000個字元長。如果遇見#字元,則不再進行工作。

輸出能從花紋布中剪出的最多小飾條個數,如果一塊都沒有,那就老老實實輸出0,每個結果之間應換行。

abcde a3

aaaaaa aa

#

0

3

這題的kmp演算法注意一點,就是在匹配成功後,模式串的指標不是滑到上乙個最大匹配的位置,而是直接重新匹配(即 j = - 1),其他的就沒什麼啦~~

#include #include #include #include #include #include using namespace std;

const int maxn=1010;

int nextval[maxn];

char c1[maxn],c2[maxn];

void getnextval(char str)

if(str[i]==str[j+1])

if(j==-1||str[i+1]!=str[j+1])

else

}}int kmp(char str1,char str2)

if(str1[i]==str2[j+1])

if(j==m-1)

}return ans;

}int main()

return 0;

}

剪花布條 KMP

剪花布條 hdu 2087 一塊花布條,裡面有些圖案,另有一塊直接可用的小飾條,裡面也有一些圖案。對於給定的花布條和小飾條,計算一下能從花布條中盡可能剪出幾塊小飾條來呢?input 輸入中含有一些資料,分別是成對出現的花布條和小飾條,其布條都是用可見ascii字元表示的,可見的ascii字元有多少個...

剪花布條 (KMP)

一塊花布條,裡面有些圖案,另有一塊直接可用的小飾條,裡面也有一些圖案。對於給定的花布條和小飾條,計算一下能從花布條中盡可能剪出幾塊小飾條來呢?input 輸入中含有一些資料,分別是成對出現的花布條和小飾條,其布條都是用可見ascii字元表示的,可見的ascii字元有多少個,布條的花紋也有多少種花樣。...

G 剪花布條

一塊花布條,裡面有些圖案,另有一塊直接可用的小飾條,裡面也有一些圖案。對於給定的花布條和小飾條,計算一下能從花布條中盡可能剪出幾塊小飾條來呢?input 輸入中含有一些資料,分別是成對出現的花布條和小飾條,其布條都是用可見ascii字元表示的,可見的ascii字元有多少個,布條的花紋也有多少種花樣。...