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

USACO 2.3 Longest Prefix


Trie樹+簡(jiǎn)單DP

對(duì)所有的primitives建一個(gè)Trie樹。用于查找某字符串是否為primitive。一開始的時(shí)候,我圖方便用set來(lái)存儲(chǔ),結(jié)果超時(shí)。后改成trie。
用dp[i]來(lái)保存從i開始的子串的最大prefix數(shù)。
這樣如果字符串buf[i..j]是primitive,且dp[i+j]+j>dp[i],那更新。由于primitive最長(zhǎng)為10。只需看前十個(gè)字符即可。
時(shí)間復(fù)雜度為O(10*10*n)。
ps.這題的輸入有點(diǎn)麻煩

#include?<iostream>
#include?
<fstream>
#include?
<sstream>
#include?
<set>

using?namespace?std;

struct?trie_node{
????trie_node
*?next[26];
????
bool?is_terminal;
????trie_node(){
????????memset(next,
0,sizeof(next));
????????is_terminal?
=?false;
????}
};

void?insert_str(trie_node*root,const?char*str,int?len)
{
????trie_node?
*?cur=root;

????
for(int?i=0;i<len;++i){
????????
if(?cur->next[str[i]-'A']==NULL){
????????????cur
->next[str[i]-'A']?=?new?trie_node;
????????}
????????cur?
=?cur->next[str[i]-'A'];?
????}

????cur
->is_terminal?=?true;
}

bool?find_str(trie_node*root,const?char?*str,int?len)
{
????trie_node?
*?cur?=?root;

????
for(int?i=0;i<len;++i){
????????
if(?cur->next[str[i]-'A']?==?NULL?)
????????????
return?false;
????????
else?
????????????cur?
=?cur->next[str[i]-'A'];
????}

????
if(cur->is_terminal)?
????????
return?true;
????
else
????????
return?false;
}

char?buf[200000];
int?dp[2000001];
int?buf_len;
trie_node?root;

void?input()
{
????freopen(
"prefix.in","r",stdin);
????freopen(
"prefix.out","w",stdout);

????
while(scanf("%s",buf)&&strcmp(buf,".")!=0){
//????????printf("%s?",buf);
??????????insert_str(&root,buf,strlen(buf));
????}

//????printf("\n");

????
int?c;
????buf_len
=0;
????
while(?(c=getchar())!=EOF){
????????
if(!isspace(c)){
????????????buf[buf_len
++]?=?(char)c;
//????????????printf("%c",c);
????????}
????}
//????printf("%d\n",buf_len);
}

void?solve()
{
????input();

????dp[buf_len]
=0;
????
for(int?i=buf_len-1;i>=0;--i){
???????
for(int?j=1;j<=10&&i+j-1<buf_len;++j){
???????????
if(?find_str(&root,&buf[i],j)?)
???????????????
if(dp[i+j]+j>dp[i])
???????????????????dp[i]?
=?dp[i+j]+j;
???????}?
????}

????printf(
"%d\n",dp[0]);
}

int?main(int?argc,char?*argv[])
{
????solve();?
????
return?0;
}

posted on 2009-06-23 21:13 YZY 閱讀(1464) 評(píng)論(1)  編輯 收藏 引用 所屬分類: AlgorithmUSACO動(dòng)態(tài)規(guī)劃

評(píng)論

# re: USACO 2.3 Longest Prefix[未登錄](méi) 2013-05-02 22:57 John

其實(shí)你這樣寫的話用沒(méi)用trie樹都沒(méi)什么區(qū)別。。。  回復(fù)  更多評(píng)論   

導(dǎo)航

<2009年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

統(tǒng)計(jì)

常用鏈接

留言簿(2)

隨筆分類

隨筆檔案

搜索

積分與排名

最新評(píng)論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美国产在线电影| 一区二区日韩精品| 欧美日韩久久久久久| 亚洲一区二区视频| 久久美女性网| 欧美中文在线观看国产| 狠狠色狠狠色综合日日tαg | 久久人人97超碰国产公开结果| 国产日韩成人精品| 国产日韩欧美91| 欧美激情亚洲国产| 亚洲欧美激情在线视频| 久久久久久69| 在线综合视频| 亚洲私人影吧| 亚洲国产日韩在线一区模特| 亚洲高清资源综合久久精品| 国产日韩一区二区三区在线播放 | 亚洲大片在线| 亚洲欧洲日产国产网站| 欧美亚日韩国产aⅴ精品中极品| 亚洲欧美一区二区三区久久| 欧美影院成人| 亚洲一区二区三区777| 欧美成人精品激情在线观看| 亚洲欧美日韩直播| 欧美三级乱码| 狠狠久久亚洲欧美专区| 国产精品美女www爽爽爽| 久久婷婷蜜乳一本欲蜜臀| 欧美成人xxx| 国产精品视频导航| 亚洲精品视频啊美女在线直播| 亚洲欧美中文字幕| 一区二区三区成人| 亚洲黑丝在线| 在线精品观看| 亚洲免费在线观看| 亚洲人成网站色ww在线| 久久精品亚洲精品| 国产美女精品| 国产欧美日韩一区二区三区| 亚洲美女视频网| 欧美 日韩 国产精品免费观看| 亚洲欧美日本国产有色| 欧美日韩在线电影| 欧美日韩在线播| 欧美三级中文字幕在线观看| 国产精品免费看片| 国产精品一级| 亚洲一级一区| 亚洲综合久久久久| 午夜国产精品视频免费体验区| 免费在线视频一区| 亚洲经典在线看| 亚洲欧洲日产国产综合网| 久久精品麻豆| 久久人人97超碰国产公开结果| 国产精品入口夜色视频大尺度 | 亚洲网站在线播放| 亚洲人成免费| 欧美日韩性视频在线| 欧美视频日韩视频| 亚洲片国产一区一级在线观看| 亚洲国产天堂久久综合| 久久免费视频网站| 香蕉成人久久| 国产综合久久久久久鬼色| 久久精品99国产精品日本| 亚洲一区二区精品在线| 国产精品你懂的在线| 一区免费观看| 99精品视频一区| 午夜精品视频在线| 亚洲在线不卡| 蜜臀久久99精品久久久久久9 | 欧美一区二区三区在线看 | 欧美在线一二三| 一区二区三区四区五区精品视频| 欧美日韩高清在线观看| 国产精品欧美日韩久久| 亚洲综合成人婷婷小说| 亚洲欧美在线观看| 免费国产一区二区| 最新日韩中文字幕| 欧美在线视频全部完| 亚洲女人天堂av| 国内外成人免费激情在线视频| 久久久久高清| 欧美成人一区二区在线| 亚洲欧美日韩综合国产aⅴ| 免费观看成人鲁鲁鲁鲁鲁视频| 久久久久高清| 在线综合亚洲欧美在线视频| 亚洲综合不卡| 欧美精品尤物在线| 亚洲欧美精品suv| 亚洲国产一二三| 国产精品麻豆成人av电影艾秋| 欧美在线在线| 欧美国产成人在线| 亚洲国产精品成人va在线观看| 一区二区三区你懂的| 亚洲欧美激情视频| 亚洲精品中文字| 欧美88av| 久久国产直播| 亚洲视频1区2区| 亚洲国内精品| 老司机一区二区三区| 亚洲一区二区三区午夜| 久久成人免费日本黄色| 国产一区二区中文| 亚洲美女在线观看| 在线日韩av| 欧美韩日一区二区三区| 国产精品久久久久久久久搜平片 | 一区二区三区高清不卡| 欧美—级高清免费播放| 久久久久久久精| 国产精品二区二区三区| 亚洲视频在线播放| 久久人人超碰| 欧美专区在线| 欧美午夜精品久久久久久超碰| 欧美国产免费| 极品少妇一区二区三区精品视频| 久久亚洲电影| 久久一本综合频道| 在线看一区二区| 玖玖精品视频| 国产乱肥老妇国产一区二 | 亚洲视频在线看| 一区二区三区日韩欧美精品| 亚洲精品乱码久久久久久日本蜜臀| 久久精品欧美| 亚洲精品裸体| 国产精品福利网站| 亚洲日本电影在线| 国产精品视频一二三| 99伊人成综合| 黑人一区二区三区四区五区| 亚洲免费在线视频一区 二区| 国产精品99久久久久久宅男| 欧美日本三级| 久久久久久九九九九| 好吊视频一区二区三区四区| 亚洲国产欧美一区二区三区久久| 亚洲第一综合天堂另类专| 日韩视频免费| 国产一区成人| 久久久久一区| 亚洲人www| 亚洲综合色婷婷| 国产欧美视频一区二区三区| 久久精品成人欧美大片古装| 麻豆av一区二区三区久久| 亚洲国产mv| 欧美日韩一区二区三区在线观看免 | 欧美激情一区二区三区四区 | 久久精品一区蜜桃臀影院| 老司机午夜免费精品视频| 亚洲综合不卡| 国产真实乱子伦精品视频| 久久午夜激情| 亚洲精品一区二区三区婷婷月 | 国产精品社区| 亚洲二区在线| 国产欧美在线视频| 亚洲电影免费观看高清完整版在线观看| 欧美精品v日韩精品v国产精品 | 黑人巨大精品欧美一区二区| 久久频这里精品99香蕉| 欧美一区二区三区日韩视频| 欧美成人精品h版在线观看| 亚洲日本精品国产第一区| 伊人久久综合| 欧美日韩精品在线播放| 欧美中文字幕精品| 日韩一区二区精品在线观看| 久久久久国色av免费看影院| 国产精品剧情在线亚洲| 亚洲激情综合| 亚洲第一伊人| 国产精品电影观看| 在线视频一区观看| 免费亚洲一区| 亚洲国产另类久久精品| 欧美一区二区三区四区高清 | 免费在线欧美黄色| 国产欧美日韩一级| 一本色道久久88综合日韩精品| 欧美亚洲免费电影| 欧美网站在线| 久久伊伊香蕉| 欧美成人精品在线观看| 国内外成人免费激情在线视频网站| 亚洲性感激情| 亚洲高清免费| 久久在线免费观看视频|