USACO 2.3 Longest Prefix


Trie树+简单DP

对所有的primitives建一个Trie树。用于查找某字符串是否为primitive。一开始的时候,我图方便用set来存储,结果超时。后改成trie。
用dp[i]来保存从i开始的子串的最大prefix数。
这样如果字符串buf[i..j]是primitive,且dp[i+j]+j>dp[i],那更新。由于primitive最长为10。只需看前十个字符即可。
时间复杂度为O(10*10*n)。
ps.这题的输入有点麻烦

#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 阅读(1429) 评论(1)  编辑 收藏 引用 所属分类: AlgorithmUSACO动态规划

评论

# re: USACO 2.3 Longest Prefix[未登录] 2013-05-02 22:57 John

其实你这样写的话用没用trie树都没什么区别。。。  回复  更多评论   


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   知识库   博问   管理


导航

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

统计

常用链接

留言簿(2)

随笔分类

随笔档案

搜索

积分与排名

最新评论

阅读排行榜