prefix解题报告
------------------------------------------------------------------------------------------------------------------------------------------------
【题目】
  给你许多子串P和一个长字符串S,请问S的前缀中能用这些子串(可以重复使用子串)组合的最长的一个长度是多少?
【数据范围】
  P的长度在1~10之内,子串个数在1~200之内
  S的长度在1~200,000之内
【输入格式】
  首先给出用空白分割的各个子串P,以独处一行的'.'字符作为结束符
  然后给出S,分多行给出,每行不超过76个字符。注意,分行符不属于S。
【输入样例】
  A AB BA CA BBC
  .
  ABABACABAABC
【输出样例】
  11
------------------------------------------------------------------------------------------------------------------------------------------------
【分析】
  简单的DP。
  输入输出不多说,bool型数组d,定义如下:d[i]==ture表示S长度为i的前缀可以被P表示出来。
  如此一来,递推下去即可,从d[i]可以更新d[i+P[j].size()],直至更新到底。
  假设有K个子串,S串长度为N,则总时间复杂度为O(NK)。
------------------------------------------------------------------------------------------------------------------------------------------------
【总结】

  有一个很严重的问题,我的代码最后一个点评测时运行时间是0.99s~1.04s之间波动,因此可能超时、可能AC……这说明我的算法应当改进,或者进行常数优化,在此特别提醒读者!
  另外,提交过程中,有几个细节问题,导致没有一次AC。这里不加赘述,因为这些错误并无借鉴意义,仅仅是因为我这道题是写了一半,放了一周,再继续写完的。。。所以错误百出。

------------------------------------------------------------------------------------------------------------------------------------------------

【代码】

 /*
ID: icedrea1
PROB: prefix
LANG: C++
*/ #include <iostream>
#include <fstream>
using namespace std; int K;
string P[],S; bool d[]; int main()
{
ifstream in("prefix.in");
ofstream out("prefix.out"); string str;
for(in>>str;str!=".";in>>str) P[++K]=str;
//cout<<"K="<<K<<endl;
//for(int i=1;i<=K;++i) cout<<"P["<<i<<"]="<<P[i]<<endl;
while(in>>str) S+=str;
S="."+S;
//cout<<"12345678901234567890123456789012345678901234567890123456789012345678901234567890";
//cout<<"S.size="<<S.size()<<endl;
//cout<<S<<endl; d[]=true;
for(int i=;i!=S.size();++i)
if(d[i])
{
//cout<<"d["<<i<<"]=true"<<endl;
for(int j=;j<=K;++j)
if(S.find(P[j],i+)==i+) d[i+P[j].size()]=true;
}
for(int i=S.size();i>=;--i)
if(d[i]) { out<<i<<endl; break; } in.close();
out.close();
return ;
}

USACO Section2.3 Longest Prefix 解题报告 【icedream61】的更多相关文章

  1. USACO Section2.1 The Castle 解题报告

    castle解题报告 —— icedream61 博客园(转载请注明出处)--------------------------------------------------------------- ...

  2. USACO Section2.1 Ordered Fractions 解题报告

    frac1解题报告 —— icedream61 博客园(转载请注明出处)---------------------------------------------------------------- ...

  3. USACO Section2.1 Healthy Holsteins 解题报告 【icedream61】

    holstein解题报告 --------------------------------------------------------------------------------------- ...

  4. USACO Section2.2 Preface Numbering 解题报告 【icedream61】

    preface解题报告----------------------------------------------------------------------------------------- ...

  5. USACO Section2.1 Hamming Codes 解题报告 【icedream61】

    hamming解题报告----------------------------------------------------------------------------------------- ...

  6. USACO Section2.3 Controlling Companies 解题报告 【icedream61】

    concom解题报告------------------------------------------------------------------------------------------ ...

  7. USACO Section2.3 Money Systems 解题报告 【icedream61】

    money解题报告------------------------------------------------------------------------------------------- ...

  8. USACO Section2.3 Zero Sum 解题报告 【icedream61】

    zerosum解题报告----------------------------------------------------------------------------------------- ...

  9. USACO Section2.3 Cow Pedigrees 解题报告 【icedream61】

    nocows解题报告------------------------------------------------------------------------------------------ ...

随机推荐

  1. 显示C++ vector中的数据

    C++ 中的vector是一个容器数据类型,不能使用cout直接显示容器中的值. 以下程序中,myvector 是一个vector数据类型.将myvector替换为需要输出的vector. for(i ...

  2. IOS 发布程序(打包上传)

    • 发布程序的主要步骤 登录开发者主页 生成cer证书:cer是一个跟电脑相关联的证书文件,让电脑具备发布程序的功能 添加App ID:发布哪些app? 生成MobileProvision文件:生成一 ...

  3. 的NodeJS异步数据库函数需要同步的答案 +

    我是新来的NodeJS和我写,需要从我去过的所有的函数应该是在这种情况下,读QUERY我的MySQL数据库,并返回代码,我非常希望服务器能够对其他事件作出回应而这个地方是轨迹查询请求.然而,它并不特别 ...

  4. css3中的 @Keyframes

    一.介绍 keyframes被称为关键帧,其类似于Flash中的关键帧.在CSS3中其主要以“@keyframes”开头,后面跟着是动画名称加上一对花括号“{…}”,括号中是一些不同时间段样式规则. ...

  5. Python基础之字符串(str)常用操作

    1.字符串常用的方法 len()返回字符串的长度 ##Python3 >>> print(len('ab12我')) 5 ##Python2 >>> print(l ...

  6. C编程经验总结4

    {}体里的语句不管在一行还是在多行,之间都是要有: for与for之间可以是独立的,也可以是相互嵌套的 For( ; i<5; )=for( ;i<=4;  ) 一般都是在循环里面进行判断 ...

  7. 使用phpExcel将数据批量导出

    if(isset($_POST['export']) && $_POST['export'] == '导出所选数据') { //此处为多选框已勾选的数据 $export_id=$_PO ...

  8. 【杂题总汇】UVa-1627 Team them up!

    [UVa-1627] Team them up! 借鉴了一下hahalidaxin的博客……了解了思路,但是莫名Wa了:最后再找了一篇dwtfukgv的博客才做出来

  9. RocketMQ源码分析之RocketMQ事务消息实现原理中篇----事务消息状态回查

    上节已经梳理了RocketMQ发送事务消息的流程(基于二阶段提交),本节将继续深入学习事务状态消息回查,我们知道,第一次提交到消息服务器时消息的主题被替换为RMQ_SYS_TRANS_HALF_TOP ...

  10. javascript中string对象方法中的slice、substring、substr的区别联系

    1.slice.substring.snustr均属于String的对象方法,用于截取或提取字符串片段,三者均布破坏原先的字符串,而是以新的字符串返回被提取的部分. <script> va ...