青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

zoj2744_Palindromes

Posted on 2010-10-13 11:00 李東亮 閱讀(1646) 評論(0)  編輯 收藏 引用

ZOJ 2744 Palindromes

這道題要求出一個長度不大于5000的字符串所有子串中回文字符串的個數。可以用暴力brute-force方法解決,但是會TLE。上網搜索了一下大家的解決方案,主要有兩種:DP法和分治法。仔細消化了一下,感覺受益匪淺。

首先說下DP方法,其實碰到這種具有很多重復計算的子問題的問題,很容易想到動態規劃DP。對于這個問題可以這樣理解:每次都從下標0開始搜索長度依次為23、……、n的子串,長度為1的子串肯定是回文。所以可以設立數組bool dp[n][n],其中dp[i][i]=truedp[i][j]表示字符串中從ij的子串是否是回文,這樣對于上面的搜索過程,要判斷str[i-j]要是否回文,可以分為兩種情況:

1.      ij之間沒有其它字符,所以只要str[i]==str[j]即可。

2.      ij之間還有其它的字符,則要求str[i]==str[j]并且dp[i+1][j-1]=true。這也很好理解,從i+1j-1的子串是回文,再兩端加上相同的字符,肯定也是回文。

參考代碼如下:

#include <cstdio>
#include 
<cstdlib>
#include 
<iostream>
#include 
<cstring>
using namespace std;

char s[5001];
bool dp[5001][5001];

int main(void)
{
    
int i, j;
    
int len;
    
int cnt;
    
int k;
    
while(gets(s))
    {
        len 
= strlen(s);
        cnt 
= len;
        
for (i = 0; i < len; ++i)
        {
            dp[i][i] 
= 0;
        }
        
for (i = 1; i < len; ++i)
        {
            
for (j = 0; j < len-i; ++j)
            {
                k 
= i+j;
                dp[j][k] 
= false;
                
if (s[j] == s[k])
                {
                    
if (j+1 < k-1)
                    {
                        
if (dp[j+1][k-1])
                        {
                            dp[j][k] 
= true;
                            
++cnt;
                        }
                    }
                    
else
                    {
                        dp[j][k] 
= true;
                        
++cnt;
                    }
                }
            }
        }
        printf(
"%d\n", cnt);
    }
    
return 0;
}

第二種思路是分治法,對于每個字符可以以它為中心向兩端擴展,依次判斷,這樣同樣避免了很多重復判斷。在擴展過程中,如果擴展到當前情況發現不是回文,這可以停止擴展。

擴展時需要分兩種情況:

1.奇數子串擴展。例如對于字符串ababa,從a[2]=a開始擴展,奇數擴展會考慮a兩邊的b,是回文,繼續向外擴展。

2.偶數子串擴展。對于同樣的字符串,從a[2]=a開始擴展 ,都屬擴展會依次考慮子串a[1-2]=ba不是回文,停止擴展。

參考代碼如下:

#include<stdio.h>
#include
<string.h>
int count=0;
char s[5001];   
int main(){
       
int k,l,r;
       
int len;
       
while(gets(s)){
              count
=0;               
              len
=strlen(s);        
              
for(k=1;k<len-1;k++){  
                     l
=k-1,r=k+1;
                     
while(l>=0&&r<len){  //奇數長度串
                            if(s[l--]==s[r++])
                                   count
++;
                            
else
                                   
break;
                     }
                     l
=k-1,r=k;
                     
while(l>=0&&r<len){   //偶數長度串
                            if(s[l--]==s[r++])
                                   count
++;
                            
else
                                   
break;
                     }
                    
              }
              
if(s[len-1]==s[len-2])  //偶數長度的串少算了最后兩個字符,補上
                     count++;
              count
+=len;   
              printf(
"%d\n",count);
       }    
       
return 0;
}



只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


posts - 12, comments - 1, trackbacks - 0, articles - 1

Copyright © 李東亮

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久久久久穴| 亚洲欧美日韩在线观看a三区| 精品成人国产在线观看男人呻吟| 一区二区三区高清不卡| 亚洲免费福利视频| 国产精品美女一区二区在线观看| 亚洲自拍16p| 蜜桃久久av一区| 一区二区久久久久| 久久国产乱子精品免费女| 亚洲午夜精品国产| 亚洲欧美综合网| 亚洲欧美变态国产另类| 精品成人国产| 日韩视频在线一区二区三区| 午夜久久美女| 久久av免费一区| 久久婷婷国产综合精品青草| 亚洲欧美日韩综合国产aⅴ| 在线亚洲精品| 久久精品一区四区| 亚洲欧美日韩国产一区二区| 亚洲国产清纯| 日韩视频―中文字幕| 午夜精品偷拍| 在线亚洲高清视频| 在线观看视频欧美| 亚洲自拍偷拍视频| 一区二区欧美日韩视频| 午夜精品久久久久| 欧美日韩精品福利| 香蕉免费一区二区三区在线观看| 亚洲午夜日本在线观看| 久久综合免费视频影院| 蜜桃av噜噜一区二区三区| 狂野欧美激情性xxxx| 亚洲大片在线| 欧美高清一区二区| 久久国产加勒比精品无码| 欧美激情免费观看| 一本综合精品| 中国成人黄色视屏| 99国产成+人+综合+亚洲欧美| 欧美一级理论性理论a| 欧美一区二区三区喷汁尤物| 欧美日本一道本| 国产精品99久久久久久人| 欧美一区二区成人6969| 欧美一级淫片播放口| 亚洲一区二区精品视频| 亚洲国产欧美在线人成| 亚洲国产91| 久久综合色影院| 欧美成人一区二区在线| 亚洲经典在线看| 91久久精品美女高潮| 欧美激情bt| 国产精品入口夜色视频大尺度| 性欧美大战久久久久久久免费观看| 亚洲高清激情| 亚洲天堂激情| 国产精品伊人日日| 欧美va亚洲va香蕉在线| 欧美日韩成人一区二区三区| 夜夜嗨av一区二区三区| 一区二区av| 亚洲精品美女在线| 亚洲国产裸拍裸体视频在线观看乱了 | 亚洲免费观看在线观看| 久久久久久久久久久久久女国产乱| 亚洲美女精品成人在线视频| 欧美国产日韩亚洲一区| 久久久久久久波多野高潮日日| 免费成人你懂的| 久久精品国产一区二区电影| 久久精品av麻豆的观看方式| 午夜精品区一区二区三| 欧美综合二区| 国产精品丝袜91| 午夜精品在线视频| 亚洲国产成人高清精品| 久久精品中文字幕一区二区三区| 在线视频亚洲欧美| 亚洲欧美视频| 国产精品久久久爽爽爽麻豆色哟哟| 99re亚洲国产精品| 亚洲高清不卡| 亚洲国产高清aⅴ视频| 国产精品都在这里| 一区二区日韩伦理片| 性欧美暴力猛交69hd| 国产欧美va欧美va香蕉在| 国产欧美一区视频| 国产精品99久久久久久人| 亚洲福利视频在线| 亚洲影院高清在线| 欧美激情视频在线播放 | 久久se精品一区精品二区| 亚洲最新视频在线播放| 91久久久久| 国产资源精品在线观看| 亚洲激情视频在线播放| 中文久久精品| 久久久噜噜噜久久中文字免| 欧美福利在线| 亚洲图片欧美日产| 亚洲综合日韩在线| 午夜精品国产精品大乳美女| 久久成人在线| 国产精品久久一区二区三区| 欧美在线观看www| 久久se精品一区二区| 免费观看久久久4p| 欧美护士18xxxxhd| 亚洲国产国产亚洲一二三| 亚洲欧美日韩中文播放| 99精品免费网| 亚洲精品欧美激情| 亚洲一区二区三区精品视频| 美女网站在线免费欧美精品| 亚洲视频一区二区在线观看| 欧美视频日韩视频在线观看| 久久久精品国产一区二区三区| 久久福利视频导航| 国产精品不卡在线| 伊人色综合久久天天| 一区二区欧美亚洲| 亚洲精品一区久久久久久| 欧美亚洲免费高清在线观看| 久久久福利视频| 国产精品素人视频| av成人毛片| 女仆av观看一区| 午夜精品电影| 亚洲精品国产精品国自产观看浪潮| 亚洲福利国产精品| 亚洲欧洲一区二区三区在线观看| 老司机aⅴ在线精品导航| 久久久久久九九九九| 亚洲欧美日韩国产一区| 亚洲欧美三级伦理| 在线国产亚洲欧美| 欧美日韩一本到| 欧美精品在线观看播放| 亚洲人成人77777线观看| 99在线热播精品免费| 久久人人97超碰精品888 | 亚洲电影免费观看高清完整版在线观看| 欧美成人国产va精品日本一级| 欧美在线视频全部完| 国产欧美日韩精品一区| 久久激情婷婷| 久久高清免费观看| 亚洲激情中文1区| 牛牛国产精品| 午夜精品一区二区三区在线视| 久久婷婷丁香| 欧美大片在线观看一区二区| 亚洲视频欧美在线| 亚洲一区二区免费在线| 韩国女主播一区二区三区| 欧美黄色影院| 日韩视频在线观看免费| 一区二区三区免费看| 99在线精品视频在线观看| 国产一区二区三区精品久久久| 夜色激情一区二区| 亚洲欧洲三级电影| 欧美淫片网站| 午夜视黄欧洲亚洲| 好看不卡的中文字幕| 久久人人97超碰国产公开结果| 国产亚洲欧美激情| 亚洲毛片在线| 亚洲一区二区三区中文字幕在线| 欧美午夜宅男影院| 亚洲欧美日韩视频一区| 久久午夜视频| 日韩一二三区视频| 欧美伊人久久久久久久久影院| 麻豆精品一区二区av白丝在线| 亚洲第一偷拍| 欧美视频在线视频| 一区电影在线观看| 夜夜嗨av色一区二区不卡| 欧美一级夜夜爽| 国产一区二区三区自拍| 在线一区亚洲| 欧美一区在线看| 一区二区av在线| 欧美日韩在线综合| 久久亚洲电影| 一本大道av伊人久久综合| 欧美在线免费播放| 欧美一区二区精品| 欧美色区777第一页| 欧美综合激情网| 在线一区欧美| 99pao成人国产永久免费视频| 免费精品99久久国产综合精品|