OIFC 2025.11.25 模拟赛总结

news/2025/11/25 16:20:11/文章来源:https://www.cnblogs.com/zhang-kevin/p/19268948

生日当天还有模拟赛(

T1 Pocky游戏

题意简述

Mdk 和 Hmr 正在吃 Pocky,她们感到有些无聊,于是决定玩一个小游戏。

现在有一根长度为 \(n\) 的 Pocky,其中从左往右数第 \(i\) 单位长度 Pocky 的美味值为 \(a_i\)。现在 Mdk 和 Hmr 决定吃掉这根 Pocky,Mdk 从左往右吃,Hmr 从右往左吃。

  • Mdk 先开始吃,她会从左侧吃 \(1\)\(2\) 单位长度的 Pocky。

  • 接下来,如果上一个人吃了 \(k\) 单位的 Pocky,则下一个人可以吃 \(k\)\(k + 1\)(如果剩余长度 \(\geq k + 1\))单位的 Pocky。

  • 如果剩下的 Pocky 长度小于 \(k\),则这个游戏将会停止。

双方都想要最大化自己吃掉的 Pocky 的美味值减掉对方吃掉的 Pocky 的美味值,问在双方都使用最优策略的情况下,Mdk 吃掉的 Pocky 的美味值减去 Hmr 吃掉的 Pocky 的美味值将会是多少?

数据范围:\(1 \leq n \leq 4000, |a_i| \leq 10^4\)空间限制:\(256 MB\)

题解

类似博弈论,所以可以直接写 dfs 求解。

具体地,我们令 \(f_{l, r, k}\) 表示两个人分别到了 \(l, r\),且上一个人走到了 \(k\),会得到的结果。转移方程与博弈论模型类似,是 \(\max\) 里面套两个 \(\min\)

这样做,转移是 \(\mathcal{O}(1)\) 的,但状态是 \(\mathcal{O}(n^3)\) 的,需要优化。

注意到 \(k\) 不会很大,因为很快就取完了。具体地,需要满足 \(\frac{k(k + 1)}{2} \leq n\),因此 \(k\) 这一维开到 \(90\) 即可。

另一方面,两个人轮流取数,所以差不会太大。由于每次取 \(k\)\(k + 1\),所以一个回合最多差 \(1\),即总共不会差超过 \(\sqrt{n}\)

这样,状态就优化成 \(n \cdot \sqrt{n} \cdot \sqrt{n}\) 了,可以通过。

参考代码(记搜版):

#include<bits/stdc++.h>
//#define int long long
using namespace std;
inline int read(){int x = 0, f = 1;char ch = getchar();while(!isdigit(ch)){if(ch == '-') f = -1;ch = getchar();}while(isdigit(ch)){x = (x << 1) + (x << 3) + (ch ^ 48);ch = getchar();}return x * f;
}
inline void write(int x){if(x < 0) putchar('-'), x = -x;if(x > 9) write(x / 10);putchar(x % 10 + '0');return;
}
const int _ = 0;
int n, s[4005], val[4005][90][90][2];
bool vis[4005][90][90][2];
inline int dfs(int l, int r, int k, int p){if(vis[l][r - l + 1][k][p]) return val[l][r - l + 1][k][p];int res = ~(0^_^0);if(p == 0)if(r - l + 1 < k)res = 0;else if(r - l + 1 >= k + 1)res = max(dfs(l + k, r, k, 1) + s[l + k - 1] - s[l - 1], dfs(l + k + 1, r, k + 1, 1) + s[l + k] - s[l - 1]);elseres = dfs(l + k, r, k, 1) + s[l + k - 1] - s[l - 1];elseif(r - l + 1 < k)res = 0;else if(r - l + 1 >= k + 1)res = min(dfs(l, r - k, k, 0) - s[r] + s[r - k], dfs(l, r - (k + 1), k + 1, 0) - s[r] + s[r - (k + 1)]);elseres = dfs(l, r - k, k, 0) - s[r] + s[r - k];vis[l][r - l + 1][k][p] = true;return val[l][r - l + 1][k][p] = res;
}
signed main(){freopen("game.in", "r", stdin);freopen("game.out", "w", stdout);n = read();for(int i = 1; i <= n; i++) s[i] = s[i - 1] + read();write(dfs(1, n, 1, 0));return 0;
}

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

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

相关文章

实验三.类和对象

任务1. button.hpp#pragma once#include <iostream> #include <string>class Button { public:Button(const std::string &label_);const std::string& get_label() const;void click();private:s…

企业微信会话内容存档功能测试,能获取成员或客户以及群消息内容,通过拉取可以将消息备份到自己服务器

wx:llike620 gofly.v1kf.com 经过几天的仔细测试和摸索,我终于把企业微信客服的会话内容存档功能给彻底搞明白了。这个功能看似强大,但实际上有不少“坑”,今天就来和大家分享我的发现。 会话存档能做什么? 当我们…

桂林高中一对一辅导机构权威榜单:2025阳朔、龙胜等地区辅导机构综合实力榜

在桂林,从秀峰区、象山区的学区房家长到阳朔、龙胜的乡镇家庭,“孩子偏科严重却找不到对症的老师”、“线下机构收费高效果却参差不齐”、“想了解学习进度还要反复联系班主任”已成为无数高中家庭的共同焦虑。 广西…

T701793 网络延迟 (latency) 赛后题解

题目传送门 思路 根据定义,用户终端 \(a\) 的顺序就是在树上从左往右的叶子节点。 可以发现建树时相当于每次选两个相邻的点,满足 \(|a_i-a_{i+1}|\le1\),将他们连起来,父节点权值为 \(\min(a_i,a_{i+1})\),即删掉…

RoadRunner与其他PHP服务器相比之优势 - 详解

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

Sentaurus .tdr文件导出数据,重新画图

借助前人编好的matlab代码,链接如下:https://ww2.mathworks.cn/matlabcentral/fileexchange/49951-sentauruslab 首先需要将 Sentaurus tdr 文件转成 .tif文件,命令行如下: tdx -tf -M 0 inputfile.tdr 例子 导出电…

桂林一对一家教辅导实用测评:2025秀峰、象山等地区辅导机构全维度对比

在桂林,从秀峰、象山的学区房家长到临桂、灵川的陪读家庭,从全州、兴安的务工家庭到阳朔、龙胜的教育重视型父母,“孩子偏科严重却找不到对症下老师”、“辅导机构收费高效果却参差不齐”、“想了解学习进度还要反复…

MATLAB锂离子电池伪二维(P2D)模型实现

锂离子电池伪二维(P2D)模型的MATLAB实现。该模型基于Newman等人提出的经典电化学模型,考虑了固液相扩散、电荷守恒和电化学反应动力学。 % 锂离子电池伪二维(P2D)模型 % 参考文献: Doyle, M., Fuller, T. F., & N…

2025年纺织机械润滑油定做厂家权威推荐榜单:汽车制造润滑油/工业润滑油/原厂防冻液源头厂家精选

在纺织行业智能化转型的浪潮中,一台纺织机械的故障停工一天,可能导致上万元的经济损失。量身定制的专用润滑油,正是保障这些设备持久稳定运行的“血液”。 纺织机械润滑油定制市场,正随着工业升级而稳步增长。据行…

EasyExcel按模板导出excel

@GetMapping("/download1")public void downloadFile1(HttpServletResponse response) throws IOException {// 下载excelString fileName = "excel-template/test.xls";response.setContentType(…

2025年市场有实力的清障车公司口碑推荐榜,蓝牌重载清障车/清障车带吊/黄牌清障车/重载清障车/拖吊联体清障车清障车公司口碑推荐榜

行业权威榜单发布,五大清障车品牌实力解析 随着国内道路救援行业的快速发展,清障车市场需求持续增长。据行业数据显示,2024年我国清障车市场规模已突破百亿元,预计2025年将保持稳定增长态势。基于市场表现、产品实…

2025下半年广东东莞套管、绝缘套管、热收缩套管、热缩套管、热缩管源头生产厂家选购终极指南:五大优质厂商深度解析

摘要 随着新能源、智能制造等行业的快速发展,2025年套管市场需求持续增长,绝缘保护套管作为关键零部件,其质量直接影响整个产品的安全性和可靠性。本文基于市场调研和行业数据,为您推荐五家优秀的套管生产企业,排…

2025年钢管表面喷涂处理生产商权威推荐榜单:高效自动喷油设备/全自动喷油生产线/普压自动喷油机源头厂家精选

钢管表面喷涂处理作为工业防腐与美化的关键环节,其技术水准直接关系到钢管的耐久性与应用范围。根据工业涂装行业数据统计,表面处理设备市场正伴随能源、建筑等下游行业的发展而持续增长。本文基于技术实力、产能数据…

墨西哥旺季物流压力大:售后客服如何做好主动通知?

墨西哥市场在旺季期间常常出现订单激增、物流时效被压缩的情况。无论是跨境电商还是本地仓配模式,只要进入大促节点,延迟、爆仓、清关慢等问题就会频繁出现。消费者的耐心有限,物流透明度又不高,如果售后客服不能及…

【数字逻辑】24进制LED综合控制实战!10灯精准执行(74HC161+138+139完整方案) - 指南

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

微算法科技(NASDAQ :MLGO)利用燃烧证明POB共识机制提高区块链网络安全性

随着区块链技术的飞速发展,其应用场景不断拓展,但网络安全性一直是备受关注的关键问题。传统的共识机制如工作量证明存在能源消耗大等局限,权益证明又面临着权益集中等挑战,微算法科技(NASDAQ: MLGO)提出的燃烧…

澳洲线路绕路多成本高:如何选择高质量语音供应商?

在跨境业务不断扩张的背景下,越来越多企业开始进入澳大利亚市场。然而,不少企业在搭建呼叫中心或外呼团队时都会遇到同一个问题:澳洲线路成本高、绕路多、语音质量不稳定。表面上看只是“打电话贵、容易掉线”,但在…

桂林小学一对一补习机构终极评测:2025七星、雁山等地区热门辅导机构真实评测

“补习怕选错,耽误孩子黄金期。”这是桂林象山区张女士在家长群里的无奈吐槽,也戳中了无数小学家长的痛点。她的孩子三年级,数学计算总出错、语文阅读理解抓不住重点,半年内换了3家辅导机构,结果却是:“老师只讲…

rust语言枚举类型enum与模式匹配

在 Rust 中,enum(枚举类型,Enumeration)是一种极其强大和灵活的类型定义方式。它允许你定义一个类型,该类型可以是几种可能变体(variants)中的任意一种。 与许多其他语言(如 C/C++)中的枚举不同,Rust 的枚举…

11.22 NOIP 模拟赛 T1. 破乱的诗歌

思路 场上考虑的其实很有道理来着考虑左右字符集已经相同的情况是简单的 否则一定要把左右字符集调整到相同那我们首先不难发现一个至少要使用的区间, 计算方法比较复杂, 但是宗旨是把左右字符集调整到相同且可匹配的必…