news 2026/4/23 13:27:43

[NOI2009] 诗人小G题解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
[NOI2009] 诗人小G题解

P1912 [NOI2009] 诗人小G

题目描述

小 G 是一个出色的诗人,经常作诗自娱自乐。但是,他一直被一件事情所困扰,那就是诗的排版问题。

一首诗包含了若干个句子,对于一些连续的短句,可以将它们用空格隔开并放在一行中,注意一行中可以放的句子数目是没有限制的。小 G 给每首诗定义了一个行标准长度(行的长度为一行中符号的总个数),他希望排版后每行的长度都和行标准长度相差不远。显然排版时,不应改变原有的句子顺序,并且小 G 不允许把一个句子分在两行或者更多的行内。在满足上面两个条件的情况下,小 G 对于排版中的每行定义了一个不协调度, 为这行的实际长度与行标准长度差值绝对值的PPP次方,而一个排版的不协调度为所有行不协调度的总和。

小 G 最近又作了几首诗,现在请你对这首诗进行排版,使得排版后的诗尽量协调(即不协调度尽量小),并把排版的结果告诉他。

输入格式

输入文件中的第一行为一个整数TTT,表示诗的数量。

接下来为TTT首诗,这里一首诗即为一组测试数据。每组测试数据中的第一行为三个由空格分隔的正整数N,L,PN,L,PN,L,P,其中:NNN表示这首诗句子的数目,LLL表示这首诗的行标准长度,PPP的含义见问题描述。

从第二行开始,每行为一个句子,句子由英文字母、数字、标点符号等符号组成(ASCII 码33∼12733 \sim 12733127,但不包含-)。

输出格式

对于每组测试数据,若最小的不协调度不超过101810^{18}1018,则第一行为一个数,表示不协调度。接下来若干行,表示你排版之后的诗。注意:在同一行的相邻两个句子之间需要用一个空格分开。

如果有多个可行解,它们的不协调度都是最小值,则输出任意一个解均可。若最小的不协调度超过101810^{18}1018,则输出Too hard to arrange。每组测试数据结束后输出--------------------,共 20 个--的 ASCII 码为 45,请勿输出多余的空行或者空格。

输入输出样例 #1

输入 #1

4 4 9 3 brysj, hhrhl. yqqlm, gsycl. 4 9 2 brysj, hhrhl. yqqlm, gsycl. 1 1005 6 poet 1 1004 6 poet

输出 #1

108 brysj, hhrhl. yqqlm, gsycl. -------------------- 32 brysj, hhrhl. yqqlm, gsycl. -------------------- Too hard to arrange -------------------- 1000000000000000000 poet --------------------

说明/提示

样例输入输出 1 解释

前两组输入数据中每行的实际长度均为666,后两组输入数据每行的实际长度均为444。一个排版方案中每行相邻两个句子之间的空格也算在这行的长度中(可参见样例中第二组数据)。每行末尾没有空格。

数据规模与约定

::cute-table{tuack}

测试点TTTNNNLLLPPP
111≤10\le 1010≤18\le1818≤100\le 100100≤5\le55
222^≤2×103\le 2\times 10^32×103≤6×104\le 6\times 10^46×104≤10\le1010
333^^^^
444≤5\le 55≤105\le 10^5105≤200\le 200200^
555^^^^
666^^≤3×106\le 3\times 10^63×106222
777^^^^
888^^^≤10\le1010
999^^^^
101010^^^^

所有句子的长度不超过303030

思路

DP

代码见下

#include<bits/stdc++.h>usingnamespacestd;longlongt,n,l,p,a[100005],b[100005],od=0,op=0,q[100005],h,g,w[100005];longdoublef[100005],wd=1e18;structone{longlongx,y;}c[100005];string s[100005];longdoublepow2(longdoublea1,longlongb1){longdoublec1=1;for(inti=1;i<=b1;i++){c1=c1*a1;// if(c1>wd){// c1=wd*2+8;// break;// }}returnc1;}longdoubleabc(longlongi,longlongj){returnf[j]+pow2(fabs(l-(a[i]-a[j]-1)),p);}longlongrr(longlonga1,longlongb1){longlongl=a1,r=n,md=n+1,mid;while(l<=r){mid=(l+r)/2;if(abc(mid,a1)>=abc(mid,b1)){md=min(md,mid);r=mid-1;}else{l=mid+1;}}returnmd;}intmain(){cin>>t;while(t--){cin>>n>>l>>p;for(inti=1;i<=n;i++){cin>>s[i];a[i]=a[i-1]+s[i].size()+1;}for(inti=1;i<=n;i++){f[i]=wd+7;}b[0]=-1;q[1]=0;w[1]=0;h=g=1;for(inti=1;i<=n;i++){while(h<=g-1&&w[h]<=i){h++;}f[i]=abc(i,q[h]);b[i]=q[h];while(h<=g-1&&w[g-1]>=rr(q[g],i)){g--;}w[g]=rr(q[g],i);q[++g]=i;}if(f[n]>wd){cout<<"Too hard to arrange"<<endl;cout<<"--------------------"<<endl;}else{cout<<(longlong)f[n]<<endl;// op=0;// for(int i=n;i>=1;i=b[i]){// c[++op]={b[i]+1,i};// }// for(int i=1;i<=op;i++){// for(int j=c[i].x;j<=c[i].y-1;j++){// cout<<s[j]<<" ";// }// cout<<s[c[i].y]<<endl;// }cout<<"--------------------"<<endl;}}return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 12:21:45

百度网盘高速下载新方案:三步突破限速瓶颈

还在为百度网盘那令人困扰的下载速度而烦恼吗&#xff1f;每天看着几十KB的缓慢下载&#xff0c;重要文件却迟迟无法获取&#xff1f;现在&#xff0c;一款创新的百度网盘解析工具让你彻底告别这种困境&#xff01; 【免费下载链接】baidu-wangpan-parse 获取百度网盘分享文件的…

作者头像 李华
网站建设 2026/4/23 10:48:54

scrapy-python基于大数据爬虫技术的B站数据分析可视化系统_8dbm860u--论文python springboot 转

文章目录系统截图项目简介大数据系统开发流程主要运用技术介绍爬虫核心代码展示结论源码文档获取定制开发/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;系统截图 scrapy-python基于大数据爬虫技术的B站数据分析可视化系统_8dbm860u–论文python s…

作者头像 李华
网站建设 2026/4/23 10:49:56

C# 与西门子 PLC 通信:地址相关核心知识点

C# 对接西门子 PLC 的核心痛点集中在地址解析、数据类型匹配、通信适配三大维度&#xff0c;而地址是所有交互的基础 —— 其格式、归属区域、与数据类型的绑定关系直接决定通信成败。以下是地址相关的核心知识点&#xff0c;结合 C# 开发场景拆解&#xff0c;覆盖底层逻辑、实…

作者头像 李华
网站建设 2026/4/23 12:25:22

求解一元一次方程(仅含+、-、x)

在算法题中&#xff0c;求解一元一次方程是一个经典的字符串处理与数学结合的问题。本文将带大家实现一个函数&#xff0c;能够解析仅包含 、 - 、变量 x 及其系数的方程&#xff0c;并返回指定格式的解。问题分析给定一个一元一次方程字符串&#xff08;如 x5-3x6x-2 &am…

作者头像 李华
网站建设 2026/4/23 10:47:59

G-Helper华硕优化工具:3分钟快速配置,性能调优秘诀全解析

G-Helper华硕优化工具&#xff1a;3分钟快速配置&#xff0c;性能调优秘诀全解析 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops. Control tool for ROG Zephyrus G14, G15, G16, M16, Flow X13, Flow X16, TUF, Strix, Scar and other mo…

作者头像 李华
网站建设 2026/4/23 10:49:58

Wallpaper Engine下载器终极指南:3步实现创意工坊壁纸自由

Wallpaper Engine下载器终极指南&#xff1a;3步实现创意工坊壁纸自由 【免费下载链接】Wallpaper_Engine 一个便捷的创意工坊下载器 项目地址: https://gitcode.com/gh_mirrors/wa/Wallpaper_Engine 还在为繁琐的壁纸下载流程而烦恼吗&#xff1f;Wallpaper Engine下载…

作者头像 李华