CF825F String Compression 解题报告

时间:2023-01-20 15:57:45

CF825F String Compression

题意

给定一个串s,其中重复出现的子串可以压缩成 “数字+重复的子串” 的形式,数字算长度。

只重复一次的串也要压。

求压缩后的最小长度。

数据范围

\(0 \le |s| \le 8,000\)

时空范围:

2sec 512mb


时空范围让我们基本可以\(O(N^2)\)做了

先考虑如果原串的每一个子串都求出了它的压缩后长度存在了\(cnt[i][j]\)里,我们就可以很方便的做DP了

令\(dp[i]\)表示长为\(i\)的串的最小压缩程度

\(dp[i]=min_{j=0}^{i-1}(dp[j]+cnt[j+1][i])\)

考虑求出每一个串的压缩后长度

枚举每一个位置为起点的子串,求出此时的\(nxt\)数组

则如果子串的子串中有从头开始循环的串,我们可以用子串的子串的长度\(len-nxt[len]\)得到循环节的长度

如下图

CF825F String Compression 解题报告

如果长度可以整除循环节的长度,则求出长度。否则直接为原长度+1


Code:

#include <cstdio>
#include <cstring>
int min(int x,int y){return x<y?x:y;}
const int N=8010;
int dp[N],nxt[N],cnt[N][N],n;
char c[N];
int get(int x)
{
int cnt=0;
while(x)
{
cnt++;
x/=10;
}
return cnt;
}
int main()
{
scanf("%s",c+1);
n=strlen(c+1);
memset(dp,0x3f,sizeof(dp));
dp[0]=0;
for(int i=1;i<=n;i++)
{
memset(nxt,0,sizeof(nxt));
cnt[i][i]=2;
nxt[i]=i-1;
for(int j=i+1,k=i-1;j<=n;j++)
{
while(k!=i-1&&c[k+1]!=c[j]) k=nxt[k];
if(c[k+1]==c[j]) k++;
nxt[j]=k;
int len=j+1-i;
if(len%(len-nxt[j]+i-1)==0)
cnt[i][j]=(len-nxt[j]+i-1)+get(len/(len-nxt[j]+i-1));
else
cnt[i][j]=len+1;
}
}
for(int i=1;i<=n;i++)
for(int j=0;j<i;j++)
dp[i]=min(dp[i],dp[j]+cnt[j+1][i]);
printf("%d\n",dp[n]);
return 0;
}

2018.7.25

CF825F String Compression 解题报告的更多相关文章

  1. 【LeetCode】443&period; String Compression 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 使用额外空间 不使用额外空间 日期 题目地址:htt ...

  2. 【LeetCode】186&period; Reverse Words in a String II 解题报告 &lpar;C&plus;&plus;&rpar;

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 每个单词单独翻转+总的翻转 日期 题目地址:https ...

  3. 【LeetCode】604&period; Design Compressed String Iterator 解题报告&lpar;C&plus;&plus;&rpar;

    作者: 负雪明烛 id: fuxuemingzhu 个人博客:http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 维护当前字符和次数 日期 题目地址:https://l ...

  4. 【LeetCode】942&period; DI String Match 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...

  5. 【LeetCode】541&period; Reverse String II 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 Java解法 Python解法 日期 题目地址:ht ...

  6. 【LeetCode】557&period; Reverse Words in a String III 解题报告(Java & Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 Java解法 Python解法 日期 题目地址:ht ...

  7. 【LeetCode】686&period; Repeated String Match 解题报告(Python & C&plus;&plus;)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 日期 题目地址:https://leetcode.c ...

  8. LeetCode 557 Reverse Words in a String III 解题报告

    题目要求 Given a string, you need to reverse the order of characters in each word within a sentence whil ...

  9. LeetCode 942 DI String Match 解题报告

    题目要求 Given a string S that only contains "I" (increase) or "D" (decrease), let N ...

随机推荐

  1. 利用Angularjs测试引擎Karma进行自动化单元测试

    Karma是Google用于angularjs框架单元测试的js引擎(javascript test runner ), angular1 和angular2项目源码的单元测试都是基于karma和ja ...

  2. 移动端REM布局方案

    引用http://www.w3cplus.com/mobile/lib-flexible-for-html5-layout.html的方案 下载地址https://github.com/hupan50 ...

  3. Meta http-equiv属性详解

    http-equiv顾名思义,相当于http的文件头作用,它可以向浏览器传回一些有用的信息,以帮助正确和精确地显示网页内容,与之对应的属性值为content,content中的内容其实就是各个参数的变 ...

  4. Hibernate&lpar;一&rpar;之Hibernate入门

    一.Hibernate入门 ssh框架体系结构 1.1.ORM框架 Hibernate是一个数据持久化层的ORM框架. Object:对象,java对象,此处特指JavaBean Relational ...

  5. js设置睡眠N秒后再执行

    function sleep(NumMillis) { var nowTime = new Date(); var exitTime = nowTime .getTime() + NumMillis; ...

  6. jmeter(四)HTTP请求

    启动jmeter,建立一个测试计划 这里再次说说怎么安装和启动jmeter吧,昨天下午又被人问到怎样安装和使用,我也是醉了:在我看来,百度能解决百分之八十的问题,特别是基础的问题... 安装:去官网下 ...

  7. django 403问题

    C:\Users\x\pyp1>python manage.py runserverPerforming system checks... System check identified no ...

  8. Spark Multilayer perceptron classifier &lpar;MLPC&rpar;多层感知器分类器

    多层感知器分类器(MLPC)是基于前馈人工神经网络(ANN)的分类器. MLPC由多个节点层组成. 每个层完全连接到网络中的下一层. 输入层中的节点表示输入数据. 所有其他节点,通过输入与节点的权重w ...

  9. &lbrack;daily&rsqb;&lbrack;editer&rsqb; 二进制编辑工具 hyx

    用了众多之后,终于发现了一个好用的二进制编辑工具: hyx https://yx7.cc/code/ https://en.wikipedia.org/wiki/Comparison_of_hex_e ...

  10. 如何让一个input输入框居中

    <div style="text-align:center;vertical-align:middel;"><input type="text&quot ...