BZOJ 1563 诗人小G
Description
Input
Output
对于每组数据,若最小的不协调度不超过\(10^{18}\),则第一行一个数表示不协调度若最小的不协调度超过\(10^{18}\),则输出"\(Too\;hard\;to\;arrange\)"(不包含引号)。每个输出后面加"\(--------------------\)"。
Sample Input
4
4 9 3
brysj,
hhrhl.
yqqlm,
gsycl.
4 9 2
brysj,
hhrhl.
yqqlm,
gsycl.
1 1005 6
poet
1 1004 6
poet
Sample Output
108
\(--------------------\)
32
\(--------------------\)
Too hard to arrange
\(--------------------\)
1000000000000000000
\(--------------------\)
【样例说明】
前两组输入数据中每行的实际长度均为\(6\),后两组输入数据每行的实际长度均为\(4\)。一个排版方案中每行相邻两个句子之间的空格也算在这行的长度中(可参见样例中第二组数据)。每行末尾没有空格。
Hint
1D1D动态规划裸题。
dp方程:$$f_{i}=min(f_{j}+(pre_{i}-pre_{j}+1)^{p})$$
方便起见,我们在\(pre_{i}\)上加个\(1\),于是dp方程变为$$f_{i}=min(f_{j}+(pre_{i}-pre_{j})^{p})$$
这个方程很明显地满足单调性(令对于\(f_{i}\)的转移\(k\)优于\(j\)(\(k > j\)),则对于\(v>i\)的\(f_{v}\)的转移也有\(k\)优于\(j\))。
斜率优化优化很明显当\(p \ne 2\)是行不通的。所以我们转向\(O(nlogn)\)的1D1D的动态规划。
1D1D动态规划是用二分单调栈来实现的。原理便是决策单调性,对于每个已经确定的\(f_{i}\),看其能更新的那一段后缀为那一段。在单调栈中进行二分,与之前的决策进行比较。不懂可以参考一下代码,代码应该好懂:
#include<cstring>
#include<cstdio>
#include<cstdlib>
using namespace std;
#define limit (1e18)
#define maxn 100010
#define maxm 40
int N,L,P,pre[maxn],top;
char s[maxm];
long double f[maxn];
struct node { int l,r,key; }stack[maxn];
inline long double qsm(int a,int b)
{
long double ret = 1;
while (b--) ret *= 1.0*a;
return ret;
}
inline long double calc(int a,int b)
{
return f[b]+qsm(abs(pre[a]-pre[b]-L),P);
}
inline int find(int a)
{
int l = 1,r = top,mid;
while (l <= r)
{
mid = (l + r) >> 1;
if (stack[mid].l<=a&&stack[mid].r>=a) return stack[mid].key;
if (a < stack[mid].l) r = mid - 1;
else l = mid + 1;
}
}
inline void updata(int now)
{
int l = 1,r;
while (top)
{
if (calc(stack[top].l,stack[top].key) >= calc(stack[top].l,now))
--top;
else
{
l = stack[top].l,r = stack[top].r;
while (l <= r)
{
int mid = (l + r) >> 1;
if (calc(mid,stack[top].key) >= calc(mid,now)) r = mid - 1;
else l = mid + 1;
}
stack[top].r = r;
break;
}
}
if (l <= N) stack[++top] = (node){l,N,now};
}
inline void dp()
{
f[0] = 0;
stack[top = 1] = (node) {1,N,0};
for (int i = 1;i <= N;++i)
{
int key = find(i);
f[i] = calc(i,key);
updata(i);
}
}
int main()
{
freopen("1563.in","r",stdin);
freopen("1563.out","w",stdout);
int T; scanf("%d",&T);
while (T--)
{
scanf("%d %d %d\n",&N,&L,&P);
L++;
for (int i = 1;i <= N;++i)
{
scanf("%s",s);
pre[i] = strlen(s)+1+pre[i-1];
}
dp();
if (f[N] > limit) printf("Too hard to arrange\n");
else printf("%.0Lf\n",f[N]);
printf("--------------------\n");
}
fclose(stdin); fclose(stdout);
return 0;
}
BZOJ 1563 诗人小G的更多相关文章
- [BZOJ 1563] [NOI 2009] 诗人小G(决策单调性)
[BZOJ 1563] [NOI 2009] 诗人小G(决策单调性) 题面 一首诗包含了若干个句子,对于一些连续的短句,可以将它们用空格隔开并放在一行中,注意一行中可以放的句子数目是没有限制的.小 G ...
- 1563: [NOI2009]诗人小G
1563: [NOI2009]诗人小G https://lydsy.com/JudgeOnline/problem.php?id=1563 分析: 直接转移f[i]=f[j]+cost(i,j),co ...
- C++之路进阶——codevs2933(诗人小G)
2933 诗人小G 2009年NOI全国竞赛 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 小G是一个出色的诗人 ...
- LG1912 [NOI2009]诗人小G
题意 题目描述 小G是一个出色的诗人,经常作诗自娱自乐.但是,他一直被一件事情所困扰,那就是诗的排版问题. 一首诗包含了若干个句子,对于一些连续的短句,可以将它们用空格隔开并放在一行中,注意一行中可以 ...
- bzoj1563: [NOI2009]诗人小G 决策单调性(1D1D)
目录 题目链接 题解 代码 题目链接 bzoj1563: [NOI2009]诗人小G 题解 \(n^2\) 的dp长这样 \(f_i = min(f_j + (sum_i - sum_j - 1 - ...
- 【Luogu1912】【NOI2009】诗人小G(动态规划)
[Luogu1912][NOI2009]诗人小G(动态规划) 题面 洛谷 题解 原来\(NOI\)这么多神仙题... 考虑一个极其明显的\(dp\) 设\(f[i]\)表示前\(i\)个句子产生的最小 ...
- BZOJ1563/洛谷P1912 诗人小G 【四边形不等式优化dp】
题目链接 洛谷P1912[原题,需输出方案] BZOJ1563[无SPJ,只需输出结果] 题解 四边形不等式 什么是四边形不等式? 一个定义域在整数上的函数\(val(i,j)\),满足对\(\for ...
- [NOI2009]诗人小G --- DP + 决策单调性
[NOI2009]诗人小G 题目描述: 小G是一个出色的诗人,经常作诗自娱自乐. 但是,他一直被一件事情所困扰,那就是诗的排版问题. 一首诗包含了若干个句子,对于一些连续的短句,可以将它们用空格隔开并 ...
- NOI 2009A 诗人小G
NOI 2009A 诗人小G 诗人小G [问题描述] 小G是一个出色的诗人,经常作诗自娱自乐.但是,他一直被一件事情所困扰,那就是诗的排版问题. 一首诗包含了若干个句子,对于一些连续的短句,可以将它们 ...
随机推荐
- iOS开发总结-类似京东分类,UICollectionView
// // TypeViewController.m // BJ // // Created by shirenfeng on 16/11/6. // Copyright © 2016年 com.ws ...
- AFNetworking 使用总结
NSString *URLTmp = @""; NSString *URLTmp1 = [URLTmp stringByAddingPercentEscapesUsingEncod ...
- Unix/Linux 脚本中 “set -e” 的作用
----------------------------------------------------------- #!/bin/bash set -e command 1 command 2 . ...
- guice框架的入门使用
guice框架是一种类似于spring的ioc容器的一种框架,使用简单,比較轻量级的一个框架,速度极快,灵活性极强,如今就先来写几个guice的程序. 在这里我就不给出guice的jar包,这些都能够 ...
- UML应用:业务内涵的分析抽象&表达
上一篇,架构设计的UML图形思考 ,简介了图形思考设计.表达设计对于架构师的重要意义,以及简介了使用统一建模语言UML描写叙述类以及类之间的继承关系,这样的描写叙述还停留在写代码,表达的但是说是怎样写 ...
- svn 树冲突
情况类似如下:(其中 removed_directory 是你工作的某个目录) 代码如下 复制代码 $svn statusD C removed_directory> local ...
- Android四大组件之一:ContentProvider(内容提供者)
Android中还提供了名为ContentProvider(内容提供者),可以向其他应用提供数据,但不常用,除非是同一公司开发的App,可以向不同应用提供数据.虽然为Android的四大组件之一,但用 ...
- 层模型--相对定位(position:relative)
如果想为元素设置层模型中的相对定位,需要设置position:relative(表示相对定位),它通过left.right.top.bottom属性确定元素在正常文档流中的偏移位置.相对定位完成的过程 ...
- node 裁剪图片
1.前端一般用Jcrop这个jq插件 要返回 x: 图片 x坐标 y: 图片 y坐标 w: 图片 宽度 h: 图片 高度 2.node 实现 var images = require("im ...
- SGU 157.Patience
简单的搜索,在n>10时,要打表 code: #include<stdio.h> #include<string.h> #include<algorithm> ...