Codeforces Round #272 (Div. 1)C(字符串DP)_html/css_WEB-ITnose

WBOY
發布: 2016-06-24 11:56:24
原創
877 人瀏覽過

C. Dreamoon and Strings

time limit per test

1 second

memory limit per test

256 megabytes

input

standard input

output

standard output

Dreamoon has a string s and a pattern string p. He first removes exactly x characters from s obtaining string s' as a result. Then he calculates  that is defined as the maximal number of non-overlapping substrings equal to p that can be found in s'. He wants to make this number as big as possible.

More formally, let's define  as maximum value of  over all s' that can be obtained by removing exactly x characters froms. Dreamoon wants to know  for all x from 0 to |s| where |s| denotes the length of string s.

Input

The first line of the input contains the string s (1?≤?|s|?≤?2?000).

The second line of the input contains the string p (1?≤?|p|?≤?500).

Both strings will only consist of lower case English letters.

Output

Print |s|?+?1 space-separated integers in a single line representing the  for all x from 0 to |s|.

Sample test(s)

input

aaaaaaa
登入後複製

output

2 2 1 1 0 0
登入後複製

input

axbaxxbab
登入後複製

output

0 1 1 2 1 1 0 0
登入後複製

题意:RT


思路:dp[i][j]表示s的前i个字符一共匹配了j个p串,删掉的最少字符数


            先用一个数组en[i]预处理出在s串的每个位置i,直到能最早匹配p串的结束的位置


            转移为dp[ en[i+1] ][j+1]= min (dp[ en[i+1] ][j+1] ,dp[ i ][j] + (en[i+1]-i-m) )


來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板