• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            misschuer

            常用鏈接

            統(tǒng)計(jì)

            積分與排名

            百事通

            最新評(píng)論

            hdu 1513 poj 1159 vijos 1327 Palindrome

            http://acm.hdu.edu.cn/showproblem.php?pid=1513
            #include <iostream>
            using namespace std;
            #define M 5002
            short dp[ M ][ 3 ];//dp[ i ][ j ]從第i個(gè)開始 長度為j的子串最少需要添加幾個(gè)字符來構(gòu)成回文
            //只有j , j - 1 , j - 2有用所以只要開辟3個(gè)就夠
            char str[ M ];
            int main(){
                
            int i , n , j , k , f;
                
            while (scanf ("%d%*c" , &n) == 1){
                    gets(str);
                    dp[ 
            0 ][ 0 ] = 0;
                    
            for (i = 1;i <= n;++ i){
                        dp[ i ][ 
            1 ] = 0;
                        dp[ i ][ 
            0 ] = 0;
                    }


                    
            for (j = 2;j <= n;++ j){
                        
            for (i = 1;i <= n - j + 1;++ i){
                            
            if (str[i - 1== str[i + j - 2]){
                                dp[ i ][j 
            % 3= dp[i + 1][(j + 1% 3];
                            }

                            
            else{
                                k 
            = (j + 2% 3;
                                
            if (dp[ i ][ k ] < dp[i + 1][ k ])
                                    dp[ i ][j 
            % 3= dp[ i ][ k ] + 1;
                                
            else
                                    dp[ i ][j 
            % 3= dp[i + 1][ k ] + 1;
                            }

                        }

                    }

                    printf (
            "%d\n" , dp[ 1 ][n % 3]);
                }

                
            return 0;
            }
            遞推方程
            str[i-1]==str[i+j-2] dp[i][j]=dp[i+1][j-2];
            str[i-1]!=str[i+j-2] dp[i][j]=MIN(dp[i][j-1],dp[i+1][j-1])+1;

            posted on 2010-04-12 12:15 此最相思 閱讀(446) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久综合狠狠综合久久| 亚洲国产精品久久| 久久久久亚洲av无码专区喷水| 亚洲AV日韩精品久久久久久| AV无码久久久久不卡蜜桃| 久久国产美女免费观看精品| 亚洲伊人久久大香线蕉综合图片| 国产激情久久久久影院老熟女| 亚洲人AV永久一区二区三区久久| 国产精品视频久久| 伊人久久大香线蕉综合影院首页| 国产A级毛片久久久精品毛片| 日本强好片久久久久久AAA | 中文字幕亚洲综合久久菠萝蜜| 久久Av无码精品人妻系列| 热RE99久久精品国产66热| 国产精品久久久久国产A级| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 久久www免费人成精品香蕉| 久久综合综合久久综合| 久久人人爽人人爽人人av东京热 | 婷婷久久久亚洲欧洲日产国码AV| 久久99精品久久久久久噜噜| 国产精品免费福利久久| 久久久久亚洲AV无码网站| 亚洲精品乱码久久久久久| 亚洲人成电影网站久久| 麻豆国内精品久久久久久| 四虎国产精品成人免费久久| 欧美性大战久久久久久 | 一本一本久久A久久综合精品| 久久99这里只有精品国产| 亚洲欧美国产精品专区久久| 国产精品久久久久久久久久影院| 久久乐国产精品亚洲综合| 久久久久99精品成人片三人毛片 | 亚洲七七久久精品中文国产| 久久受www免费人成_看片中文| 久久婷婷国产剧情内射白浆| 亚洲国产精品无码久久SM| 国产韩国精品一区二区三区久久|