PKU 1159 Palindrome

来源:互联网 发布:网络通信软件 编辑:程序博客网 时间:2024/05/21 04:22

 PKU 1159 Palindrome  http://acm.pku.edu.cn/JudgeOnline/problem?id=1159

还是LCS,但数据改到了5000, 很容易超内存,要注意!

我用的是滑动数组的方法实现内存优化的:

 

#include <iostream>

using namespace std;

char a[5001];

int y[5001];

int temp[5001];

int main()

{

         short i,j,n;

         while (scanf("%d",&n)!=EOF)

         {

                   scanf("%s",a+1);

                   for (i=0;i<5001;i++)

                   {

                            y[i] = temp[i] = 0;

                   }

                   for (i=1;i<=n;i++)

                   {

                            for (j=1;j<=n;j++)

                            {

                                     if (a[i] == a[n-j+1]) //如果相等

                                     {

                                               if (j-1 == 0)

                                               {

                                                        temp[j] = 1;

                                               }

                                               else

                                                        temp[j] = y[j-1] + 1;

                                     }

                                     else // 如果不相等

                                     {

                                               if (j-1 == 0)

                                               {

                                                        temp[j] = y[j];

                                               }

                                               else

                                                        temp[j] = y[j] > temp[j-1] ?  y[j] : temp[j-1];

                                     }

                            }

                            for (j=1;j<=n;j++)

                            {

                                     y[j] = temp[j];

                                     temp[j] = 0;

                            }

                   }

                   printf("%d/n",n - y[n]);

         }

         return 0;

}

 

原创粉丝点击