時間限制:
3000 ms | 記憶體限制:
65535 kb
難度:4 描述
所謂回文字串,就是乙個字串,從左到右讀和從右到左讀是完全一樣的,比如"aba"。當然,我們給你的問題不會再簡單到判斷乙個字串是不是回文字串。現在要求你,給你乙個字串,可在任意位置新增字元,最少再新增幾個字元,可以使這個字串成為回文字串。
輸入第一行給出整數n(0
輸出每行輸出所需新增的最少字元數
樣例輸入
1ab3bd
樣例輸出
2
設f[i][j]表示從第i個字元到第j個字元要變為回文需要新增的字元個數,由此可以得到狀態轉移方程為
1、str[i]==str[p]:f[i][j]=f[i+1][j-1];
2、str[i]!=str[p]:f[i][j] = min(f[i][p-1],f[i+1][p]);
**如下:#include #includeusing namespace std;
int f[1010][1010];//f[i][j]表示從i到j要新增的最少的字元個數
int main()
{ int n;
cin>>n;
while(n--)
{char str[1010];
cin>>str;
int i,j,k,len = strlen(str);
for(i=0;i
NYOJ 37 回文字串
思想 在紙上測試幾組資料,發現先逆轉原來的字串,再用原來的字串跟逆轉後的字串進行比較,求得的最長公共子串行就是回文串,也就是不需要新增的,再用總長度減去最長公共子串行就可以得到最少需要新增的字元數。就簡單了,以前寫過的稍稍改下就直接貼上來了。include includeint f 1001 100...
nyoj 37 回文字串
時間限制 3000 ms 記憶體限制 65535 kb 難度 4 描述 所謂回文字串,就是乙個字串,從左到右讀和從右到左讀是完全一樣的,比如 aba 當然,我們給你的問題不會再簡單到判斷乙個字串是不是回文字串。現在要求你,給你乙個字串,可在任意位置新增字元,最少再新增幾個字元,可以使這個字串成為回文...
nyoj 37 回文字串
時間限制 3000 ms 記憶體限制 65535 kb 難度 4 描述 所謂回文字串,就是乙個字串,從左到右讀和從右到左讀是完全一樣的,比如 aba 當然,我們給你的問題不會再簡單到判斷乙個字串是不是回文字串。現在要求你,給你乙個字串,可在任意位置新增字元,最少再新增幾個字元,可以使這個字串成為回文...