拆分数列

题目背景

【为了响应党中央勤节俭、反铺张的精神,题目背景描述故事部分略去-

题目描述

给出一列数字,需要你添加任意多个逗号将其拆成若干个严格递增的数。

如果有多组解,则输出使得最后一个数最小的同时,字典序最大的解(即先要满足最后一个数最小;如果有多组解,则使得第一个数尽量大;如果仍有多组解,则使得第二个数尽量大,依次类推……)。

输入输出格式

输入格式:

共一行,为初始的数字。

输出格式:

共一行,为拆分之后的数列。每个数之间用逗号分隔。行尾无逗号。

数据范围

对于\(10\%\)的数据,输入长度\(\le5\)

对于\(30\%\)的数据,输入长度\(\le15\)

对于\(50\%\)的数据,输入长度\(\le50\)

对于\(100\%\)的数据,输入长度\(\le500\)


这个题还挺巧妙的。

发现要求是字典序构造,而且两组要求看起来不太一样。

考虑分开做,先在保证有解的情况下找到最后一个最小的数。

令\(dp_i\)代表以\(i\)为结束时的字符串的最大前缀位置(即满足最后一位最小),这样我们每次找的都是最小的位,具有最优子结构性质。

转移:

$$dp_i=max_{num_{j,i}>num_{dp_{j-1},j-1},j\le i} \ j$$

\(num_{i,j}\)代表从\(i\)到\(j\)的数字大小

注意比较的复杂度,所以总体是\(O(n^3)\)的,不过上界非常松

然后我们再反着做一遍类似的\(DP\),发现还是由最大前缀推了最大前缀的,所以刚好满足了要求\(2\)

注意前导\(0\)的一些特判


Code:

#include <cstdio>
#include <cstring>
const int N=502;
int n,dp[N];
char s[N];
bool check(int l1,int r1,int l2,int r2)//前是否大于后
{
if(r2==0) return 1;
while(s[l1]=='0'&&l1<=r1) ++l1;
while(s[l2]=='0'&&l2<=r2) ++l2;
if(r1-l1>r2-l2) return 1;
else if(r1-l1<r2-l2) return 0;
while(l1<=r1&&l2<=r2&&s[l1]==s[l2]) ++l1,++l2;
return s[l1]>s[l2];
}
int main()
{
scanf("%s",s+1);
n=strlen(s+1);
for(int i=1;i<=n;i++)
for(int j=i;j;j--)
if(check(j,i,dp[j-1],j-1))
{
dp[i]=j;
break;
}
int d=dp[n],pos=dp[n];
memset(dp,0,sizeof(dp));
dp[pos]=n;
while(s[pos-1]=='0') --pos,dp[pos]=n;
for(int i=pos-1;i;i--)
for(int j=d;j>=i;j--)
if(check(j+1,dp[j+1],i,j))
{
dp[i]=j;
break;
}
for(int l=1,r;l<=n;l=r+1)
{
r=dp[l];
for(int j=l;j<=r;j++) printf("%c",s[j]);
if(r!=n) printf(",");
}
return 0;
}

2018.10.21

洛谷 P1415 拆分数列 解题报告的更多相关文章

  1. 洛谷P1415 拆分数列[序列DP 状态 打印]

    题目背景 [为了响应党中央勤节俭.反铺张的精神,题目背景描述故事部分略去^-^] 题目描述 给出一列数字,需要你添加任意多个逗号将其拆成若干个严格递增的数.如果有多组解,则输出使得最后一个数最小的同时 ...

  2. 洛谷P1415 拆分数列(dp)

    题目链接:传送门 题目: 题目背景 [为了响应党中央勤节俭.反铺张的精神,题目背景描述故事部分略去^-^] 题目描述 给出一列数字,需要你添加任意多个逗号将其拆成若干个严格递增的数.如果有多组解,则输 ...

  3. 洛谷P1415 拆分数列

    题目背景 [为了响应党中央勤节俭.反铺张的精神,题目背景描述故事部分略去^-^] 题目描述 给出一列数字,需要你添加任意多个逗号将其拆成若干个严格递增的数.如果有多组解,则输出使得最后一个数最小的同时 ...

  4. 洛谷 P2609 [ZJOI2012]数列 解题报告

    P2609 [ZJOI2012]数列 题目描述 小白和小蓝在一起上数学课,下课后老师留了一道作业,求下面这个数列的通项公式: A(0)=0 A(1)=1 A(2i)=A(i) (对于任意 i>0 ...

  5. 洛谷 P4597 序列sequence 解题报告

    P4597 序列sequence 题目背景 原题\(\tt{cf13c}\)数据加强版 题目描述 给定一个序列,每次操作可以把某个数\(+1\)或\(-1\).要求把序列变成非降数列.而且要求修改后的 ...

  6. 洛谷 P1783 海滩防御 解题报告

    P1783 海滩防御 题目描述 WLP同学最近迷上了一款网络联机对战游戏(终于知道为毛JOHNKRAM每天刷洛谷效率那么低了),但是他却为了这个游戏很苦恼,因为他在海边的造船厂和仓库总是被敌方派人偷袭 ...

  7. 洛谷1087 FBI树 解题报告

    洛谷1087 FBI树 本题地址:http://www.luogu.org/problem/show?pid=1087 题目描述 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全 ...

  8. 洛谷 P2467 地精部落 解题报告

    P2467 [SDOI2010]地精部落 题目描述 传说很久以前,大地上居住着一种神秘的生物:地精. 地精喜欢住在连绵不绝的山脉中.具体地说,一座长度为\(N\)的山脉\(H\)可分为从左到右的\(N ...

  9. 洛谷 P4128 [SHOI2006]有色图 解题报告

    P4128 [SHOI2006]有色图 题目描述 如果一张无向完全图(完全图就是任意两个不同的顶点之间有且仅有一条边相连)的每条边都被染成了一种颜色,我们就称这种图为有色图.如果两张有色图有相同数量的 ...

随机推荐

  1. dedesmc 手机端生成静态页

    dedesmc 手机端生成静态页 1.首先下载插件,下载地址:https://pan.baidu.com/s/1Nfx_KBYuxRkZ7VzoPxy28g 密码:83x7 2.进入 dedecms ...

  2. mysql数据库的基本使用命令总结

    mysql数据库是一个常用的关系型数据库 关系型数据库核心元素有哪些? 主键:特殊字段,用来唯一标识记录的唯一性 字段:数据列 记录:数据行 数据表:数据行的集合 数据库:数据表的集合 安装.启动.停 ...

  3. Hadoop(21)-数据清洗(ELT)简单版

    有一个诸如这样的log日志 去除长度不合法,并且状态码不正确的记录 LogBean package com.nty.elt; /** * author nty * date time 2018-12- ...

  4. Idea 2017 激活方法

    http://www.cnblogs.com/suiyueqiannian/p/6754091.html

  5. 《史上最简单的MySQL教程》系列分享专栏

    <史上最简单的MySQL教程>系列分享专栏 <史上最简单的MySQL教程>已整理成PDF文档,点击可直接下载至本地查阅https://www.webfalse.com/read ...

  6. (数据科学学习手札17)线性判别分析的原理简介&Python与R实现

    之前数篇博客我们比较了几种具有代表性的聚类算法,但现实工作中,最多的问题是分类与定性预测,即通过基于已标注类型的数据的各显著特征值,通过大量样本训练出的模型,来对新出现的样本进行分类,这也是机器学习中 ...

  7. 【娱乐向】制作Chrome天气预报扩展程序

    1.什么是Chrome扩展程序 Chrome扩展程序是一个用Web技术开发,用来扩展增强浏览器功能的软件.和一般的网页一样,Chrome扩展程序由html.js.css和图片等部分组成.Chrome插 ...

  8. 基于Mysql-Proxy实现Mysql的主从复制以及读写分离(上)

    基于Mysql-Proxy实现Mysql的主从复制以及读写分离(上) 上周BOSS给分配任务让实现一下Mysql数据库的主从复制以及读写分离,然后花了一盏茶的功夫进行了调研,发现主从复制数据库进行一番 ...

  9. QC的使用学习(一)

    今天学习的时间很少,就利用睡前的一点时间来学习一下刚安装好的QC. 1.后台站点管理.主要是对八大选项的了解: site project:顾名思义,就站点项目管理,管理域和项目. site user: ...

  10. BZOJ 1010 HNOI2008 玩具装箱 斜率优化

    题目链接: http://www.lydsy.com/JudgeOnline/problem.php?id=1010 Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的 ...