【题解】P11459 [USACO24DEC] Its Mooin Time P

news/2025/10/9 20:19:45/文章来源:https://www.cnblogs.com/QWQcoding/p/19131895

其实是套路题。但有段时间没写过闵可夫斯基和优化 \(dp\) 了,记录一下。

先简单回顾一下闵可夫斯基和。点集 \(P\) 与 点集 \(Q\) 的闵可夫斯基和定义为:\(P+Q=\{a+b|a\in P,b\in Q\}\)

对于两个凸包的闵可夫斯基和,有如下性质:

  1. \(P+Q\) 也为凸包。
  2. \(P+Q\) 的边集由 \(P,Q\) 的边按极角排序后连接的结果。

因此对于大小为 \(n\)\(m\) 的两个凸包,我们可以通过 \(O(n+m)\) 的时间复杂度求出它们的闵可夫斯基和。

对于 \((\max,+)\) 卷积和 \((\min,+)\) 卷积,我们也可以通过类似的方式进行优化。

\((\max,+)\) 卷积为例,设 $c_i=\max_{j+k=i}{a_j+b_k} $。

如果 \((i,a_i)\)\((i,b_i)\) 分别构成凸包,它们的闵可夫斯基和即为 \((i,c_i)\) ,那么可以通过如上方法快速求解数组 \(c\)

如何使用闵可夫斯基和优化 \(dp\) ?对于 \(f_{i,j}=\max_{k<j}\{f_{i-1,k}+a_i\}\) 这类的 \(dp\) ,其中 \(i\) 这一维可能是形如 “选择 \(i\) 个物品” 状物。我们可以退一步,将序列 \(dp\) 改为区间 \(dp\) ,然后用 \([l,mid]\)\([mid+1,r]\) 的答案合并得到 \([l,r]\) 的答案。考虑分治,这样合并两段区间的贡献相当于做闵可夫斯基和的过程,总复杂度 \(O(n\log n)\)

回到这一题,由于 \(L\) 固定,我们可以对每个 \(i\) 预先求出 \([i,i+L-1]\) 合并出 MO.. 的答案。设 \(f_{i,j}\) 表示考虑前 \(i\) 位作为 MO.. 的起点,恰好包含 \(j\)MO.. 的答案,那么转移形式与上式类似,只是要求前一个转移点与当前点相差至少 \(L\) 。将 \(dp\) 改为区间 \(dp\) ,设 \(f_{l,r,a1,a2,k}\) 表示考虑第 \(l\)\(r\) 位作为 MO.. 的起点,最左、右端的点离左右端点的距离状态分别为 \(a_1,a_2\) ,至少包含 \(k\)MO.. 的答案。其中,\(a_1,a_2\)\(0/1/2\) 分别表示距离两段距离为 \(0/1/\geq2\) 。合并连段时做类似矩阵乘法,对 \(a_1,a_2\) 做卷积。时间复杂度 \(O(nL^2\log n)\)

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
inline ll read(){ll x=0; bool f=1; char ch=getchar();while(ch<'0'||ch>'9'){if(ch=='-') f=0; ch=getchar();}while(ch>='0'&&ch<='9'){x=(x<<1)+(x<<3)+(ch^48); ch=getchar();}return f?x:-x;
}
inline void write(ll x){if(x<0) x=-x,putchar('-');if(x>9) write(x/10);putchar('0'+x%10);
}
const ll N=300009;
const ll INF=1e18;
ll L,n,c[N],a[N];
ll g[10][10];
string s;
struct Node{vector<ll> f[3][3];
};
vector<ll> merge(vector<ll> a,vector<ll> b){for(ll i=a.size()-1;i>=2;i--) a[i]-=a[i-1];for(ll i=b.size()-1;i>=2;i--) b[i]-=b[i-1];vector<ll> c(a.size()+b.size()-1);c[0]=a[0]+b[0];merge(a.begin()+1,a.end(),b.begin()+1,b.end(),c.begin()+1);for(ll i=1;i<a.size()+b.size()-1;i++){c[i]+=c[i-1];}return c;
}
void add(vector<ll>&x,vector<ll> y){while(x.size()<y.size()) x.push_back(INF);for(ll i=0;i<y.size();i++) x[i]=min(x[i],y[i]);
}
Node solve(ll l,ll r){if(r-l+1<=2*L){Node res;for(ll x=0;x<L;x++){for(ll y=0;y<L;y++){memset(g,0x3f,sizeof(g));for(ll i=l+x;i<=r-y;i++){g[i-l+1][1]=a[i];if(i-L>=l){for(ll j=2;j<=r-l+1;j++){g[i-l+1][j]=min(g[i-l+1][j],g[i-l+1-L][j-1]+a[i]);}}for(ll j=1;j<=r-l+1;j++){g[i-l+1][j]=min(g[i-l+1][j],g[i-l][j]);}}vector<ll> cur; cur.push_back(0);for(ll i=1;i<=r-l+1;i++){ll mn=INF;for(ll j=l;j<=r;j++){mn=min(mn,g[j-l+1][i]);}if(mn>=INF) break;cur.push_back(mn);}res.f[x][y]=cur;}}return res;}ll mid=(l+r)/2;auto ls=solve(l,mid),rs=solve(mid+1,r);Node res;for(ll i=0;i<=L-1;i++){for(ll j=0;j<=L-1;j++){for(ll mid=0;mid<=L-1;mid++){add(res.f[i][j],merge(ls.f[i][mid],rs.f[L-1-mid][j]));}}}return res;
}
int main(){ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);cin>>L>>n;cin>>s; s=" "+s;for(ll i=1;i<=n;i++){cin>>c[i];}for(ll i=1;i<=n-L+1;i++){if(s[i]!='M') a[i]=c[i];for(ll j=i+1;j<=i+L-1;j++){if(s[j]!='O') a[i]+=c[j];}}Node res=solve(1,n-L+1);for(ll i=1;i<=n/L;i++){cout<<res.f[0][0][i]<<"\n";}return 0;
}

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

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

相关文章

创建一个springboot项目,mybatis连接嵌入式数据库H2,实现增删改查功能

@目录目标创建一个spirngboot项目创建流程第一次运行项目,界面如下mybatis连接数据库H2依赖:mybatis + h2配置文件schema.sql实现对用户的增删改查创建entity创建mapper创建service创建controller搭配前端程序,修改…

基于众包的产品质量比较与推荐算法研究

本研究通过众包方式探索影响顾客购买决策的因素,发现顾客评论和问答内容比商家描述更能预测产品质量感知,这些发现可用于改进产品发现算法,提高推荐相关性。探索顾客购买决策背后的原因 研究背景 为了提升产品发现算…

10/9

进一步学习了链表插入的相关知识,规划了自己的实验选题系统。

2025.10.9

今日:学习英语 明日:学习英语 敲代码

深入解析:一款相机是只有桶形畸变 和 枕形畸变的一种,还是两个都有?

深入解析:一款相机是只有桶形畸变 和 枕形畸变的一种,还是两个都有?pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: &…

记忆化

记忆化记忆化搜索(减少重复计算,对搜索的优化)DFS指数级 记忆化保证了每个值只计算一次限制在了NM时间范围内=等价于DP动态规划好处:不需要考虑循环顺序,且只考虑有解的状态,相较递推效率可能更高 弊端:需要考虑边…

重组抗体技术:从原理到应用,解锁高效可控的新一代抗体研发

在抗体技术迭代中,重组抗体凭借 “基因工程改造 + 可控化生产” 的核心优势,逐渐取代传统杂交瘤抗体,成为科研、诊断与治疗领域的主流工具。它不仅解决了动物源抗体的免疫排斥问题,还能灵活设计为全长抗体、小分子…

关于jinja2的ssti模版注入的学习+过滤

查找想要的模块 cnt = 0 for item in [].__class__.__base__.__subclasses__():try:if os in item.__init__.__globals__:print(cnt, item)cnt += 1except:cnt += 1continue{% for i in range(300) %}{{ i }} - {{ .__…

WPF Epplus export 10M+ items in excel with multiple sheets batch by batch

Install-Package Epplus; private async Task ExportAsExcelCommandExecuted(object? obj) {try{await PopulateStatusMsg($"Start exporting");exportedIdx = 0;var dg = obj as DataGrid;var items = dg.…

[EGOI 2023] Guessing Game

精彩。 这篇题解有思路讲解,只想看做法的可以看其它题解。 做题第一步一定是先把题目要干什么弄清楚。不妨令这题第一个人是 A(除了最后一个访问的元素的信息填写者),第二个人是 B(接收信息者),第三个人是 C(最…

CF2152G Query Jungle

很精巧的题。 很明显求的是虚树的叶子结点数量。 然而这个玩意还带修,看起来有点恶心。不过带修的问题一般都不会很复杂,再加上子树修改我们考虑用搜索序把树拍到序列上,为了更好的刻画叶子,我们可以考虑使用性质更…

[ROI 2018] Addition without carry

还是记录一下,有点怪但是有点帅。 首先条件等价于和不进位,也就是说每一位只有一个 \(b\) 是 \(1\)。 对于 \(b_i\ge a_i\) 的限制我们可以当成 \(a_i\) 加若干非负数,考虑 check 一个答案是否合法,记得确定一个漂…

[THUPC 2025 决赛] Im Here

题目给了一刻编号为搜索序的树,我们形式化限制,考察方案序列:若 \(u\) 是 \(v\) 的祖先,则 \(u\) 在 \(v\) 后面。 第 \(i\) 个点只能出现在 \([1,n-i+1]\) 这些位置中。显然限制一是一个树上拓扑序计数的东西,我…

下好多雨

下好多雨继续hbase 和其他作业

解码Linux基础命令

Linux 基础命令 核心概念:终端、Shell 与内核的关系 Linux 中用户通过终端(Terminal)与系统交互,终端是运行Shell(命令解释器)的窗口,而 Shell 是连接用户与内核(Kernel)的桥梁:内核:系统核心,管理 CPU、内…

戴尔电脑开机出现supportassist怎么办_戴尔电脑开机出现supportassist多种解决优秀的方法

戴尔电脑开机出现supportassist怎么办_戴尔电脑开机出现supportassist多种解决优秀的方法2025-10-09 19:36 tlnshuju 阅读(0) 评论(0) 收藏 举报pre { white-space: pre !important; word-wrap: normal !important…

基于 C++ 的高雷诺数湍流直接数值模拟求解器设计与性能优化 - 实践

基于 C++ 的高雷诺数湍流直接数值模拟求解器设计与性能优化 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "…

项目经理常见面试题7:作为项目经理,你如何协调项目中不同角色(构建、测试、产品)的矛盾?

项目经理常见面试题7:作为项目经理,你如何协调项目中不同角色(构建、测试、产品)的矛盾?pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !impo…

由等概率(a,b)生成等概率(c,d)

问题描述:有一个函数,可以等概率的生成x∈(a,b),如何编写函数生成x∈(c,d) 举例f函数可以生成[1,5],生成[1,7]1 public static int f() { 2 return (int) (Math.random() * 5) + 1; 3 } 解题思路:通过f()改造成等…

是时候使用NanoID取代UUID了

是时候使用NanoID取代UUID了是时候使用NanoID取代UUID了付国强兴趣是一个人成功的基石​关注他5 人赞同了该文章 UUID是软件开发中最常用的通用标识符之一。然而,在过去的几年里,其他替代品挑战了它的存在。其中,N…