【NOI2009】诗人小G【决策单调性dp】

传送门

设句子加上空格长度前缀和为sss

转移方程为

fi=min⁡1≤j<i{fj+∣si−sj−L−1∣P}f_i=\min_{1\leq j<i}\{f_j+|s_i-s_j-L-1|^P\}fi=1j<imin{fj+sisjL1P}

不难发(cai)现(chu)决策具有单调性

本文重点讲决策单调dp的实现

由于决策单调,所以每个决策有效的都是一个区间

用队列按顺序维护所有区间

开始时加入“决策000的生效区间为整个序列”

每到一个位置,弹出所有已经失效的区间,队头就是当前最优决策,算出答案

然后用当前位置更新队列

先将队尾无用的弹掉,因为单调,所以判断如果队尾决策对区间最左边没有当前位置作为决策优,弹队尾。

如果队列中仍有元素,二分出当前砍掉的位置。

最后把挖掉的部分都用当前位置填上。注意如果没挖直接忽略

本题中由于主要是大小比较,可以牺牲精度追求值域,用long double存

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cctype>
#include <cmath>
#define MAXN 100005
using namespace std;
typedef long double ld;
struct key{int c,p;}q[MAXN];
int head,tail;
char str[MAXN][35];
int s[MAXN],n,l,p,ans[MAXN];
ld dp[MAXN];
inline ld abso(const ld& x){return x<0? -x:x;}
inline ld qpow(ld a,int p)
{ld ans=1;while (p){if (p&1) ans=ans*a;a=a*a;p>>=1;}return ans;
}
inline ld calc(int n,int i){return dp[i]+qpow(abso(s[n]-s[i]-l-1),p);}
void print(int n)
{if (!n) return;print(ans[n]);for (int i=ans[n]+1;i<=n;i++){printf("%s",str[i]);if (i<n) putchar(' ');}puts("");
}
int main()
{int T;scanf("%d",&T);while (T--){head=1,tail=0;scanf("%d%d%d",&n,&l,&p);for (int i=1;i<=n;i++) scanf("%s",str[i]),s[i]=s[i-1]+strlen(str[i])+1;q[++tail]=(key){0,n};for (int i=1;i<=n;i++){while (head<tail&&i>q[head].p) ++head;dp[i]=calc(i,ans[i]=q[head].c);while (head<=tail&&calc(q[tail-1].p+1,i)<calc(q[tail-1].p+1,q[tail].c)) --tail;if (head<=tail){int l=q[tail-1].p+1,r=q[tail].p,mid;while (l<r){mid=(l+r+1)>>1;if (calc(mid,q[tail].c)<calc(mid,i)) l=mid;else r=mid-1;}q[tail].p=l;}if (q[tail].p<n) q[++tail]=(key){i,n};}if (dp[n]>1e18) puts("Too hard to arrange");else{printf("%lld\n",(long long)dp[n]);print(n);}puts("--------------------");}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/315127.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Codeforces Round #709 (Div. 1) B. Playlist 链表维护 + bfs

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 紧跟刘爷脚步补题。 不难想到用链表维护下一个数是什么&#xff0c;这样就跟以前做过的一个题差不多了&#xff0c;首先将初始的时候删掉的点的前一个点即为题目中的AAA入队&#xff0c;让…

浅谈ASP.NET Core中IOC与DI的理解和使用

说起IOC和DI,使用过ASP.NET Core的人对这两个概念一定不陌生&#xff0c;早前&#xff0c;自己也有尝试过去了解这两个东西&#xff0c;但是一直觉得有点很难去理解&#xff0c;总觉得对其还是模糊不清&#xff0c;所以&#xff0c;趁着今天有空&#xff0c;就去把两个概念捋清…

Codeforces Round #715 (Div. 1) C. Complete the MST 补图 + 思维 + 最小生成树

传送门 文章目录题意&#xff1a;思路题意&#xff1a; 给你一张nnn个点mmm个边的图&#xff0c;mmm条边是给定的&#xff0c;要求你给未给定的边赋值一个边权&#xff0c;使得所有边权异或和为000&#xff0c;求所有满足这种情况的图中最小生成树边权和最小的&#xff0c;输出…

一个通用数据库操作组件DBUtil(c#)、支持SqlServer、Oracle、Mysql、postgres、SQLITE

这是一个.net下操作数据库(结构数据库)的工具类&#xff0c;支持sqlserver、oracle、mysql、postgres、sqlite、access等常见数据库。注意&#xff1a;它并不是一个orm工具(常见的orm框架如&#xff1a;EF、Dapper等)。2.1 引入DBUtil依赖1. 首先打开vs(推荐vs2019)&#xff0c…

【NOI2012】迷失游乐园【概率期望】【换根dp】【基环树】

传送门 题意&#xff1a;给一棵nnn个点的带边权树或基环树&#xff0c;随机选一个点作为起点&#xff0c;每次随机走到一个相邻未走过的位置&#xff0c;直到无路可走。求期望路径长度。 n≤105n \leq 10^5n≤105,为基环树时环的大小不超过202020 先考虑树怎么做废话 先只考…

Educational Codeforces Round 37 (Rated for Div. 2) E. Connected Components? 暴力 + 补图的遍历

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; n≤2e5,m≤2e5n\le2e5,m\le2e5n≤2e5,m≤2e5。 思路&#xff1a; 这是题是我上个题的一部分&#xff0c;算是个小知识点&#xff0c;暴力能过。 直接维护一个setsetset&#xff0c;让后遍历所有点&#xff…

初探System.Threading.Channels

。System.Threading.Channels是.Net Core基础类库中实现的一个多线程相关的库&#xff0c;专门处理数据流相关的操作&#xff0c;用来在生产者和订阅者之间传递数据&#xff08;不知道可不可以理解为线程间传递数据&#xff0c;我把它类比成了Go语言中的Channel&#xff09;&am…

【LOJ6033】棋盘游戏【二分图博弈】

传送门 显然是个二分图&#xff0c;设开始位置是左边&#xff0c;另一边是右边 那么先手是把左边挪到右边&#xff0c;后手是把右边挪到左边&#xff0c;不能挪的那方失败 结论&#xff1a;Alice必胜当且仅当开始位置不一定在最大匹配上 必要性&#xff1a; 如果开始位置不…

Codeforces Round #715 (Div. 1) B. Almost Sorted 找规律

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 找规律yydsyydsyyds。 一看没什么想法&#xff0c;所以打了个表&#xff0c;好家伙&#xff0c;不打不知道&#xff0c;一打不得了&#xff0c;下面是n6n6n6的符合要求的情况&#xff1a; …

SQL Server之索引解析(二)

、堆表堆表通过IAM连接一起&#xff0c;查询时全表扫描。1、1 非聚集索引结构叶子节点数据结构&#xff1a;行数据结构Rid&#xff08;8字节&#xff09;中间节点数据结构&#xff1a; &#xff08;非聚集非唯一索引&#xff09;行数据结构Page&#xff08;4&#xff09;2 Rid&…

【NOI2011】兔兔与蛋蛋的游戏【二分图博弈】

传送门 结论 不会有同一个棋子移动两次 反证法&#xff0c;对于第一个移动第二次的棋子 设两次移动之间(含)的移动的棋子为A1,A2,A3,……&#xff0c;AnA_1,A_2,A_3,……&#xff0c;A_nA1​,A2​,A3​,……&#xff0c;An​&#xff08;指棋子本身而非位置&#xff09; 因…

CF1528C dfs序+set维护

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你两棵有nnn个节点的树&#xff0c;我门记第一棵为aaa&#xff0c;第二棵为bbb&#xff0c;现在你有一个nnn个点都孤立的点集&#xff0c;两个点u,vu,vu,v可以连边当且仅当这两个点在aaa树中一个是另一个的…

纠正一个错误,分布式系统关注点第17篇

这里是Z哥的个人公众号每周五早8点 按时送达当然了&#xff0c;也会时不时加个餐&#xff5e;我的第「78」篇原创敬上今天来加个餐&#xff0c;紧急纠正一个错误。先和大家说一声抱歉&#xff1a;D昨晚睡觉前&#xff0c;惯例打开「订阅号助手」回复一些留言。有一位小伙伴提了…

【NOI2016】国王饮水记【贪心】【斜率优化】【决策单调性】

传送门 首先比h1h_1h1​小的肯定没用&#xff0c;直接无视 然后考虑合并的顺序 ①在无限制的情况下&#xff0c;合并多个不如一个一个合并 a<b<ca<b<ca<b<c时&#xff0c;ab2c2>abc3{{ab \over 2}c\over 2}>{{abc}\over 3}22ab​c​>3abc​ ②先…

CF946D Timetable 背包dp + 思维转换

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; n,m,k≤500n,m,k\le500n,m,k≤500 思路&#xff1a; 将其转换成背包的模型&#xff0c;就可以想出来一个很明显的dpdpdp状态&#xff1a;f[i][j]f[i][j]f[i][j]表示前iii行花费了jjj的最小代价&#xff0c;…

.NET开发框架(三)-高可用服务器端设计

我们对框架功能作了简述&#xff0c;演示视频请点击 这里查看 &#xff0c;本章节&#xff0c;我们专门讲解一下&#xff0c;如何在Window服务器下&#xff0c;设计高可用的框架。我们的框架设计采用的是Window版本的服务端设计&#xff1a;整体框架图如下&#xff0c;为什么我…

P1537 弹珠 背包可行性dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 疯狂水文章。 这个很明显是个背包&#xff0c;我们开一个布尔数组&#xff0c;之后枚举每组的个数&#xff0c;让后枚举1−61-61−6&#xff0c;再枚举容量kkk&#xff0c;注意顺序不能错了…

【NOI2012】骑行川藏【拉格朗日乘数法】【二分套二分】

传送门 拉格朗日乘数法裸题 限制 f({v})∑i1nkisi(vi−vi′)EUf(\{v\})\sum_{i1}^nk_is_i(v_i-v_i)E_Uf({v})i1∑n​ki​si​(vi​−vi′​)EU​ 求 g({v})∑i1nsivig(\{v\})\sum_{i1}^n\frac{s_i}{v_i}g({v})i1∑n​vi​si​​ 最小值 设 L(λ,{v})g({v})λ[f({v})−EU]∑…

.NET Core 3.0中的WinForms创建集中式拉取请求中心

Windows 窗体&#xff08;或简称 WinForms&#xff09;&#xff0c;多年来被用于开发具有丰富和交互式界面的基于 Windows 的强大应用程序。各类企业对这些桌面应用程序的投入量非常巨大&#xff0c;每月有大约 240 万开发人员使用 Visual Studio 创建桌面式应用。利用和扩展现…

CF296B dp\容斥

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; n≤1e5n\le1e5n≤1e5 思路&#xff1a; 求方案数基本就是考虑dpdpdp了&#xff0c;看到nnn这么大可以考虑一下分情况讨论的dpdpdp状态。 设f[i][j]f[i][j]f[i][j]表示到了第iii个&#xff0c;状态为jjj的方…