码迷,mamicode.com
首页 > 其他好文 > 详细

2.3.1 LONGEST PREFIX 最长前缀

时间:2014-11-06 13:09:20      阅读:176      评论:0      收藏:0      [点我收藏+]

标签:acm   c++   算法   解题报告   

题目大意:(如题)
输入输出:(如题)
解题思路:
1.简单动态规划。
2.纠结的边界处理,不建议采用dp[i]表示s前i个字符能否取得这种方法。用这种方法实现字符串储存的时候会比较麻烦。而且如果存储不对边界处理会非常麻烦……(最先我采用的是这种方法,结果WA 4次,多次处理还是有长度为0和长度为1的情况无法分辨,最终放弃)
核心代码:
lens=s.length();
    for(i=0;i<lens;i++)
    {
        for(j=0;j<cntp;j++)
        {
            flag=false;
            len=p[j].length();
            if(i+len>lens)//如果加入这个字符串超过了s的长度则不满足条件
                continue;
            for(k=0;k<len;k++)
                if(s[i+k]!=p[j][k])//有一个字符不同不满足条件
                {
                    flag=true;
                    break;
                }
            if(flag==false&&len+i>maxn)//满足条件更新最大值
                    maxn=len+i;
        }
        if(i+1>maxn)//结束条件
            break;
    }

2.3.1 LONGEST PREFIX 最长前缀

标签:acm   c++   算法   解题报告   

原文地址:http://blog.csdn.net/mmoaay/article/details/40857745

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!