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

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>
            亚洲高清视频一区| 亚洲欧美日韩专区| 亚洲欧美日韩一区| 在线亚洲电影| 在线亚洲+欧美+日本专区| 中日韩美女免费视频网址在线观看| 99一区二区| 午夜一区二区三区在线观看| 欧美一区日韩一区| 欧美aaaaaaaa牛牛影院| 亚洲欧洲一区| 亚洲日韩成人| 欧美一站二站| 欧美精品123区| 国产精品人人做人人爽| 国内精品久久久久久久影视麻豆 | 国产精品久久久久久影视 | 欧美bbbxxxxx| 日韩一级精品| 欧美在线视频导航| 欧美乱妇高清无乱码| 国产欧美视频在线观看| 亚洲精品久久久久| 欧美一级精品大片| 亚洲国产婷婷综合在线精品| 亚洲免费在线视频| 欧美精品一区二区三区在线播放 | 洋洋av久久久久久久一区| 校园春色综合网| 欧美精品国产一区| 国产一区二区三区视频在线观看 | 亚洲激情第一页| 日韩亚洲精品视频| 久久精品视频免费观看| 欧美日韩精品三区| 精品动漫3d一区二区三区免费| 中文一区二区| 最新日韩中文字幕| 久久综合九色综合欧美就去吻| 国产精品自在线| 亚洲色诱最新| 亚洲福利视频网站| 久久久久**毛片大全| 国产精品免费区二区三区观看| 亚洲精品国产精品国自产在线| 久久久91精品国产| 销魂美女一区二区三区视频在线| 国产精品国产馆在线真实露脸 | 国产精品一区二区三区观看 | 在线精品国产欧美| 欧美在线3区| 一区二区日韩欧美| 欧美日韩国产在线一区| 亚洲精品久久久久| 亚洲国产精品一区制服丝袜| 久久嫩草精品久久久精品| 国产亚洲美州欧州综合国| 欧美一区二区在线免费播放| 亚洲综合色丁香婷婷六月图片| 欧美三级日韩三级国产三级| 一区二区三区免费看| 亚洲美女性视频| 欧美日韩人人澡狠狠躁视频| 中文精品在线| 亚洲专区欧美专区| 国产日韩欧美自拍| 久久久另类综合| 久久久免费精品视频| 亚洲国产1区| 欧美激情一二区| 欧美精品一区二区蜜臀亚洲| 中文在线资源观看网站视频免费不卡| 日韩午夜激情av| 国产精品入口| 欧美~级网站不卡| 欧美精品www| 亚洲免费网站| 久久国产精品久久精品国产| 亚洲福利视频二区| 亚洲看片网站| 国产欧美视频一区二区三区| 欧美国产日韩一区二区| 欧美日韩精品在线观看| 性伦欧美刺激片在线观看| 欧美在线观看视频一区二区三区| 激情丁香综合| 日韩视频在线观看| 久久精品夜色噜噜亚洲a∨| 欧美制服丝袜| 日韩视频一区| 午夜精品久久久久久久久久久 | 韩曰欧美视频免费观看| 欧美成人在线免费观看| 欧美三区在线观看| 久久蜜桃av一区精品变态类天堂| 蜜臀a∨国产成人精品| 欧美一区二区三区男人的天堂| 久久午夜精品一区二区| 亚洲综合不卡| 蜜臀久久99精品久久久画质超高清| 亚洲无线视频| 麻豆九一精品爱看视频在线观看免费| 亚洲一区二区三区精品在线观看 | 国产精品久久久久久av下载红粉| 先锋影音国产一区| 欧美成人免费网站| 久久精品一区四区| 欧美肉体xxxx裸体137大胆| 欧美3dxxxxhd| 国产香蕉久久精品综合网| 亚洲精品中文字幕有码专区| 精品成人国产| 欧美一区二区三区日韩| 亚洲性感激情| 欧美剧在线免费观看网站| 久久综合久色欧美综合狠狠 | 性欧美videos另类喷潮| 日韩视频在线观看| 久久久免费精品| 久久婷婷av| 国产香蕉97碰碰久久人人| 中文在线资源观看网站视频免费不卡| 亚洲福利国产| 另类激情亚洲| 亚洲日本aⅴ片在线观看香蕉| 午夜精品999| 欧美日韩午夜视频在线观看| 亚洲大黄网站| 亚洲国产一区二区三区青草影视| 久久成人在线| 久久久综合激的五月天| 国产午夜精品一区理论片飘花| 亚洲无人区一区| 午夜精品久久久久久久久| 欧美性理论片在线观看片免费| 亚洲精品一区二区三区婷婷月| 亚洲精品免费一二三区| 欧美国产一区二区在线观看| 亚洲黄色片网站| 亚洲美女精品一区| 欧美精品www| 一区二区三区日韩在线观看| 亚洲综合视频网| 国产精品亚洲第一区在线暖暖韩国| 亚洲一区二区在线观看视频| 欧美一区二区三区免费大片| 亚洲免费观看视频| 欧美激情国产日韩| 日韩午夜三级在线| 亚洲一区二区毛片| 国产农村妇女毛片精品久久麻豆 | 在线视频欧美日韩精品| 欧美激情久久久| 一本一本久久a久久精品牛牛影视| 亚洲一区二区视频| 国产日韩一区欧美| 久久免费国产精品| 最新国产の精品合集bt伙计| 亚洲女优在线| 黄色欧美成人| 欧美日韩不卡在线| 小黄鸭精品aⅴ导航网站入口| 蜜臀av一级做a爰片久久| 日韩视频在线一区| 国产美女高潮久久白浆| 久久婷婷蜜乳一本欲蜜臀| 亚洲另类一区二区| 久久精品五月| 日韩视频一区二区| 国产一区二区三区直播精品电影 | 亚洲一区二区动漫| 久久久www成人免费无遮挡大片| 亚洲国产精品传媒在线观看 | 欧美国产高潮xxxx1819| 在线视频免费在线观看一区二区| 久久精品72免费观看| 日韩小视频在线观看| 国产一区二区中文字幕免费看| 欧美国产第一页| 欧美一区精品| 一本色道88久久加勒比精品 | 亚洲免费网站| 亚洲精品美女在线观看播放| 久久亚洲私人国产精品va| 一区二区三区www| 韩日在线一区| 国产精品爽爽ⅴa在线观看| 欧美插天视频在线播放| 欧美一区二区日韩| 亚洲视频免费在线| 亚洲日本理论电影| 免费影视亚洲| 久久精品人人| 午夜宅男久久久| 亚洲在线免费观看| 99精品热视频| 亚洲精品国产品国语在线app| 狠狠v欧美v日韩v亚洲ⅴ| 国产精品ⅴa在线观看h| 欧美日韩成人激情|