贪心,求出前$i$个字符串所能组成的字典序最小的字符串$ans$(特别的,这里的字典序有$ab>abc$),同时保证剩下的长度能通过$l_{i+1},...,l_{n}$拼接

考虑插入一个字符串$s_{i+1}$,在$ans$的任意拼接处(包括开头)可以替换上这个串,之后使得$ans$的字典序最小且长度合法,容易发现有:第一个能使$ans$字典序变小(这里指严格变小)的位置一定是使得$ans$字典序最小的位置(如果不存在就加在最后)

枚举插入的位置(所有合法断点的位置),相当于要判断插入后能否让$ans$更小,由于前半部分相同,即比较$s_{i+1}$和$ans$的一个后缀,暴力比较复杂度为$o(n^{2}k)$,无(ke)法(yi)通过

考虑二分+hash找到lcp,之后判断下一个字符即可,这样复杂度为$o(nk\log_{2}k)$(这里不是$o(n^{2}\log_{2}k)$的原因是需要计算hash值),常数比较优秀可以通过

还可以发现这是一个exkmp的模板题,时间复杂度可以做到$o(nk)$

然而这道题还有很多的细节,这里给出几组毒瘤的数据(/为回车):3 3/abd/ab/c,3 3/abc/ab/d,4 3/a/b/abd/c,3 3/a/aa/ab,4 4/a/a/aa/b,4 4/a/aa/c/ab(答案自己手算)

(不过atcoder的数据极水,这些数据全错+暴力求lcp都是可以通过的)

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 10005
4 int n,k,len,l[N],a[N],b[N],extend[N],f[2005][N];
5 char s[2005][N],ans[N];
6 void calc(int l1,char *s1,int l2,char *s2){
7 memset(extend,0,sizeof(extend));
8 for(int i=0;i<l1;i++)
9 while ((i+extend[i]<l1)&&(extend[i]<l2)&&(s1[i+extend[i]]==s2[extend[i]]))extend[i]++;
10 }
11 int main(){
12 scanf("%d%d",&n,&k);
13 for(int i=1;i<=n;i++){
14 scanf("%s",s[i]);
15 l[i]=strlen(s[i]);
16 }
17 f[n+1][0]=1;
18 for(int i=n;i;i--)
19 for(int j=k;j>=0;j--){
20 f[i][j]=f[i+1][j];
21 if (j>=l[i])f[i][j]|=f[i+1][j-l[i]];
22 }
23 len=a[0]=0;
24 for(int i=1;i<=n;i++){
25 calc(len,ans,l[i],s[i]);
26 b[0]=0;
27 int flag=0,lll=0,aa=0,bb=0;
28 for(int j=0,ll=0;j<=a[0];ll+=a[++j]){
29 if ((k<ll+l[i])||(!f[i+1][k-ll-l[i]])){
30 if (j<a[0])b[++b[0]]=a[j+1];
31 continue;
32 }
33 int x=extend[ll];
34 if (x==l[i]){
35 b[++b[0]]=a[j+1];
36 continue;
37 }
38 if (ll+x==len){
39 flag=1;
40 aa=j;
41 bb=b[0];
42 lll=ll;
43 if (j<a[0])b[++b[0]]=a[j+1];
44 continue;
45 }
46 if (ans[ll+x]>s[i][x]){
47 flag=0;
48 len=ll+l[i];
49 for(int p=0;p<l[i];p++)ans[ll+p]=s[i][p];
50 while ((j<a[0])&&(a[j+1]<=x)){
51 x-=a[++j];
52 l[i]-=a[j];
53 b[++b[0]]=a[j];
54 }
55 b[++b[0]]=l[i];
56 break;
57 }
58 if (j<a[0])b[++b[0]]=a[j+1];
59 }
60 if (flag){
61 int x=extend[lll],j=aa,ll=lll;
62 b[0]=bb;
63 len=ll+l[i];
64 for(int p=0;p<l[i];p++)ans[ll+p]=s[i][p];
65 while ((j<a[0])&&(a[j+1]<=x)){
66 x-=a[++j];
67 l[i]-=a[j];
68 b[++b[0]]=a[j];
69 }
70 b[++b[0]]=l[i];
71 }
72 mempcpy(a,b,sizeof(a));
73 }
74 printf("%s",ans);
75 }

[atARC058F]Lroha Loves Strings的更多相关文章

  1. [CodeForces - 447B] B - DZY Loves Strings

    B - DZY Loves Strings DZY loves collecting special strings which only contain lowercase letters. For ...

  2. Codeforces Round #254 (Div. 1) D - DZY Loves Strings

    D - DZY Loves Strings 思路:感觉这种把询问按大小分成两类解决的问题都很不好想.. https://codeforces.com/blog/entry/12959 题解说得很清楚啦 ...

  3. Codeforces Round #254 (Div. 1) D. DZY Loves Strings hash 暴力

    D. DZY Loves Strings 题目连接: http://codeforces.com/contest/444/problem/D Description DZY loves strings ...

  4. Codeforces Round #FF (Div. 2):B. DZY Loves Strings

    B. DZY Loves Strings time limit per test 1 second memory limit per test 256 megabytes input standard ...

  5. 题解-ARC058D Iroha Loves Strings

    题面 ARC058D Iroha Loves Strings 给定 \(n\) 个字符串,从中选出若干个按给出顺序连接起来,总长等于 \(m\),求字典序最小的,保证有解. 数据范围:\(1\le n ...

  6. CF447B DZY Loves Strings 贪心

    DZY loves collecting special strings which only contain lowercase letters. For each lowercase letter ...

  7. 文字列大好きいろはちゃんイージー / Iroha Loves Strings (ABC Edition) (优先队列)

    题目链接:http://abc042.contest.atcoder.jp/tasks/abc042_b Time limit : 2sec / Memory limit : 256MB Score ...

  8. HDU 5229 ZCC loves strings 博弈

    题目链接: hdu:http://acm.hdu.edu.cn/showproblem.php?pid=5229 bc:http://bestcoder.hdu.edu.cn/contests/con ...

  9. Atcoder Regular Contest 058 D - 文字列大好きいろはちゃん / Iroha Loves Strings(单调栈+Z 函数)

    洛谷题面传送门 & Atcoder 题面传送门 神仙题. mol 一发现场(bushi)独立切掉此题的 ycx %%%%%%% 首先咱们可以想到一个非常 naive 的 DP,\(dp_{i, ...

随机推荐

  1. 41 位 Contributor 参与,1574 个 PR,不容错过的版本更新!

    6 月 25 日,在商业公司 SphereEx 正式成立一月之余的今天,我们很高兴的宣布 Apache ShardingSphere 迎来了 5.0.0-beta 版本的正式发布.经过半年多的优化和打 ...

  2. 前段--->js

    一,java script的引入方式 1,直接在script里书写你的代码 <script> alert("hbflfb")</script> 2,引入额外 ...

  3. 使用ShardingSphere-JDBC完成Mysql的分库分表和读写分离

    1. 概述 老话说的好:选择比努力更重要,如果选错了道路,就很难成功. 言归正传,之前我们聊了使用 MyCat 实现Mysql的分库分表和读写分离,MyCat是服务端的代理,使用MyCat的好处显而易 ...

  4. vue3.x相对于vue2.x生命周期改动

    vue3.x已经正式发布了,部分小伙伴已经用了vue3.x开发,部分小伙伴还在观望中,下面是两个影响比较大的改动 1.beforeDestroy和destroyed不能用了. 这个应该是vue2.x项 ...

  5. 欧姆龙plc通讯协议格式

    欧姆龙CPM1A型plc与上位计算机通信的顺序是上位机先发出命令信息给PLC,PLC返回响应信息给上位 机.每次通信发送/接受的一组数据称为一"帧".帧由少于131个字符的数据构成 ...

  6. Scrum Meeting 16

    第16次例会报告 日期:2021年06月11日 会议主要内容概述: 最后一次例会 一.进度情况 我们采用日报的形式记录每个人的具体进度,链接Home · Wiki,如下记录仅为保证公开性: 组员 负责 ...

  7. Beta-技术规格说明书

    项目 内容 这个作业属于哪个课程 2021春季软件工程(罗杰 任健) 这个作业的要求在哪里 团队项目-计划-功能规格说明书 一.架构与技术栈 1.整体架构 本项目的整体架构如上图所示.下面我们将对涉及 ...

  8. 热身训练1 Sequence

    http://acm.hdu.edu.cn/showproblem.php?pid=6 分析: 这道题,全都是1e9,所以我们很容易想到"矩阵快速幂". 假如说我们没有后面那个&q ...

  9. stm32串口学习笔记

    stm32作为现在嵌入式物联网单片机行业中经常要用多的技术,相信大家都有所接触,今天这篇就给大家详细的分析下有关于stm32的出口,还不是很清楚的朋友要注意看看了哦,在最后还会为大家分享有些关于stm ...

  10. 基于live555开发嵌入式linux系统的rtsp直播服务

    最近要搞一个直播服务,车机本身是个前后双路的Dvr,前路1080P 25fps,后路720P 50fps,现在要连接手机app预览实时画面,且支持前后摄像头画面切换. 如果要做直播,这个分辨率和帧率是 ...