历年CSP-S复赛真题解析 | 2022年CSP-S复赛

​欢迎大家订阅我的专栏:算法题解:C++与Python实现!
本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战!

专栏特色
1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的代码实现与详细指导,帮助您夯实算法基础。
2.系统化学习路径:按照算法类别和难度分级,从基础到进阶,循序渐进,帮助您全面提升编程能力与算法思维。

适合人群:

  • 准备参加蓝桥杯、GESP、CSP-J、CSP-S等信息学竞赛的学生
  • 希望系统学习C++/Python编程的初学者
  • 想要提升算法与编程能力的编程爱好者

附上汇总贴:历年CSP-S复赛真题解析 | 汇总


P8818 策略游戏

【题目来源】

洛谷:[P8818 CSP-S 2022] 策略游戏 - 洛谷

【题目描述】

小 L 和小 Q 在玩一个策略游戏。

有一个长度为n nn的数组A AA和一个长度为m mm的数组B BB,在此基础上定义一个大小为n × m n \times mn×m的矩阵C CC,满足C i j = A i × B j C_{i j} = A_i \times B_jCij=Ai×Bj。所有下标均从1 11开始。

游戏一共会进行q qq轮,在每一轮游戏中,会事先给出4 44个参数l 1 , r 1 , l 2 , r 2 l_1, r_1, l_2, r_2l1,r1,l2,r2,满足1 ≤ l 1 ≤ r 1 ≤ n 1 \le l_1 \le r_1 \le n1l1r1n1 ≤ l 2 ≤ r 2 ≤ m 1 \le l_2 \le r_2 \le m1l2r2m

游戏中,小 L 先选择一个l 1 ∼ r 1 l_1 \sim r_1l1r1之间的下标x xx,然后小 Q 选择一个l 2 ∼ r 2 l_2 \sim r_2l2r2之间的下标y yy。定义这一轮游戏中二人的得分是C x y C_{x y}Cxy

小 L 的目标是使得这个得分尽可能大,小 Q 的目标是使得这个得分尽可能小。同时两人都是足够聪明的玩家,每次都会采用最优的策略。

请问:按照二人的最优策略,每轮游戏的得分分别是多少?

【输入】

第一行输入三个正整数n , m , q n, m, qn,m,q,分别表示数组A AA,数组B BB的长度和游戏轮数。

第二行:n nn个整数,表示A i A_iAi,分别表示数组A AA的元素。

第三行:m mm个整数,表示B i B_iBi,分别表示数组B BB的元素。

接下来q qq行,每行四个正整数,表示这一次游戏的l 1 , r 1 , l 2 , r 2 l_1, r_1, l_2, r_2l1,r1,l2,r2

【输出】

输出共q qq行,每行一个整数,分别表示每一轮游戏中,小 L 和小 Q 在最优策略下的得分。

【输入样例】

3 2 2 0 1 -2 -3 4 1 3 1 2 2 3 2 2

【输出样例】

0 4

【算法标签】

《洛谷 P8818 策略游戏》 #贪心# #线段树# #ST表# #CSP-S提高级# #2022# #O2优化#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;// 定义int为long long类型#defineintlonglong// 定义常量constintN=100005;// 变量定义intn,m,q;// n: 第一个序列长度, m: 第二个序列长度, q: 查询次数// ST表数组intazmax[N][32];// 存储序列a中非负数的最大值intazmin[N][32];// 存储序列a中非负数的最小值intafmax[N][32];// 存储序列a中负数的最大值intafmin[N][32];// 存储序列a中负数的最小值intbmax[N][32];// 存储序列b的最大值intbmin[N][32];// 存储序列b的最小值signedmain(){// 读入n, m, qcin>>n>>m>>q;// 读入序列a并初始化ST表for(inti=1;i<=n;i++){cin>>azmax[i][0];// 读入序列a的第i个元素if(azmax[i][0]<0)// 如果是负数{// 负数存储在afmax和afmin中afmax[i][0]=afmin[i][0]=azmax[i][0];// 非负数表设为无效值azmax[i][0]=-1;// 非负最大值设为-1azmin[i][0]=INT_MAX;// 非负最小值设为极大值}else// 如果是非负数{// 非负数存储在azmax和azmin中azmin[i][0]=azmax[i][0];// 负数表设为无效值afmax[i][0]=-INT_MAX;// 负最大值设为负无穷afmin[i][0]=0;// 负最小值设为0}}// 读入序列b并初始化ST表for(inti=1;i<=m;i++){cin>>bmax[i][0];// 读入序列b的第i个元素bmin[i][0]=bmax[i][0];// 同时赋值给最小值}// 计算log2值intlena=log2(n);// 序列a的ST表最大层数intlenb=log2(m);// 序列b的ST表最大层数// 构建序列a的非负数最大值ST表for(intj=1;j<=lena;j++){for(inti=1;i+(1<<j)-1<=n;i++){azmax[i][j]=max(azmax[i][j-1],azmax[i+(1<<(j-1))][j-1]);}}// 构建序列a的非负数最小值ST表for(intj=1;j<=lena;j++){for(inti=1;i+(1<<j)-1<=n;i++){azmin[i][j]=min(azmin[i][j-1],azmin[i+(1<<(j-1))][j-1]);}}// 构建序列a的负数最大值ST表for(intj=1;j<=lena;j++){for(inti=1;i+(1<<j)-1<=n;i++){afmax[i][j]=max(afmax[i][j-1],afmax[i+(1<<(j-1))][j-1]);}}// 构建序列a的负数最小值ST表for(intj=1;j<=lena;j++){for(inti=1;i+(1<<j)-1<=n;i++){afmin[i][j]=min(afmin[i][j-1],afmin[i+(1<<(j-1))][j-1]);}}// 构建序列b的最大值ST表for(intj=1;j<=lenb;j++){for(inti=1;i+(1<<j)-1<=m;i++){bmax[i][j]=max(bmax[i][j-1],bmax[i+(1<<(j-1))][j-1]);}}// 构建序列b的最小值ST表for(intj=1;j<=lenb;j++){for(inti=1;i+(1<<j)-1<=m;i++){bmin[i][j]=min(bmin[i][j-1],bmin[i+(1<<(j-1))][j-1]);}}// 查询变量intx1,y1,x2,y2;// 查询区间:a的[x1,y1],b的[x2,y2]intmaxy,miny;// 序列b在查询区间的最大值和最小值intmaxzx,maxfx,minzx,minfx;// 序列a在查询区间的四种极值// 处理每个查询while(q--){intans=-1e18;// 初始化答案为负无穷// 读入查询区间cin>>x1>>y1>>x2>>y2;// 查询序列b在[x2,y2]区间的最大值和最小值intk2=log2(y2-x2+1);maxy=max(bmax[x2][k2],bmax[y2-(1<<k2)+1][k2]);miny=min(bmin[x2][k2],bmin[y2-(1<<k2)+1][k2]);// 查询序列a在[x1,y1]区间的四种极值intk1=log2(y1-x1+1);maxzx=max(azmax[x1][k1],azmax[y1-(1<<k1)+1][k1]);// 非负数最大值minzx=min(azmin[x1][k1],azmin[y1-(1<<k1)+1][k1]);// 非负数最小值maxfx=max(afmax[x1][k1],afmax[y1-(1<<k1)+1][k1]);// 负数最大值minfx=min(afmin[x1][k1],afmin[y1-(1<<k1)+1][k1]);// 负数最小值// 根据序列a和b的极值计算最大乘积if(minzx!=INT_MAX)// 如果存在非负数{ans=max(ans,maxzx*miny);// 最大非负数 × 最小bans=max(ans,minzx*miny);// 最小非负数 × 最小b}if(maxfx!=-INT_MAX)// 如果存在负数{ans=max(ans,maxfx*maxy);// 最大负数 × 最大bans=max(ans,minfx*maxy);// 最小负数 × 最大b}// 输出结果cout<<ans<<endl;}return0;}

【运行结果】

3 2 2 0 1 -2 -3 4 1 3 1 2 0 2 3 2 2 4

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

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

相关文章

来学学大模型最新「合金特工」骚操作,能力比肩多智能体,AI 黑客成功率飙升

来学学大模型最新「合金特工」骚操作&#xff0c;能力比肩多智能体&#xff0c;AI 黑客成功率飙升&#xff0c;大模型入门到精通&#xff0c;收藏这篇就足够了&#xff01; 你了解过多智能体&#xff08;Multi-Agent&#xff09;吗&#xff1f;就在大家还在讨论如何让多个 AI A…

大模型上下文工程(Context Engineering)详解,小白也能轻松学会!

前言 随着大语言模型&#xff08;LLM&#xff09;的快速发展&#xff0c;从GPT-3到ChatGPT&#xff0c;再到Claude、GPT-4等更强大的模型&#xff0c;我们见证了一个重要趋势&#xff1a;上下文窗口的不断扩大。早期的模型可能只能处理几千个token&#xff0c;而现代模型已经能…

Flutter Bloc 状态管理深度解析与开源鸿蒙 ArkUI 对标分析 - 详解

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

吃出的爱意

写在前面 831 字 | 见闻 | 感触 | 想法 正文周末。晚上去餐馆吃饭。吃到一半,看见一位女性,拉着一位老人进来。女人而立上下,老人头发花白,面容近古稀。找一餐桌,坐下。女人推了一下菜单,叫老人点菜,说点三菜一…

带你真正了解什么是 I/O 多路复用(附 Java + Spring Boot 实战案例)

视频看了几百小时还迷糊&#xff1f;关注我&#xff0c;几分钟让你秒懂&#xff01; 一、前言&#xff1a;为什么我们要聊 I/O 多路复用&#xff1f; 在开发高并发网络服务&#xff08;比如聊天服务器、实时推送系统、游戏后端等&#xff09;时&#xff0c;我们经常会遇到一个…

蓝牙基础(十):蓝牙串口、文件传输、通话控制

liwen01 2026.01.02 前言 日常生活中,我们用到的很多蓝牙功能,都是基于蓝牙 RFCOMM 传输协议来实现,比如:手机与手机间通过蓝牙分享名片、短信、图片、文件等手机与车机之间的来电显示、电话接听、挂断、音量调节等…

XSS攻击进阶:攻击链路、绕过技巧与企业级防护方案

XSS攻击进阶&#xff1a;攻击链路、绕过技巧与企业级防护方案 掌握XSS基础原理与分类后&#xff0c;需进一步理解实际攻击中的完整链路、常见绕过技巧&#xff0c;以及企业级防护方案。在真实Web环境中&#xff0c;攻击者不会仅满足于弹窗&#xff0c;而是通过XSS构建完整攻击…

聊聊低温减速机供应商,鑫钺传动江苏服务性价比哪家高

在工业制造领域,低温环境下的传动设备性能直接决定生产线稳定性与运营成本,选择靠谱的低温减速机供应商关乎企业核心生产效率。面对市场上技术水平参差不齐的厂商,如何抉择?以下依据不同技术特点,为你推荐2025年低…

分析用工风险律师,靠谱的律所都有哪些

在企业经营的日常管理中,用工风险如同潜藏的暗礁,稍有不慎便可能引发劳动仲裁、经济赔偿等连锁反应,甚至影响企业的稳定运营。对于天津本地企业而言,选择一家专业可靠的用工风险律所至关重要。以下依据不同维度,为…

聊聊宁德抖音代运营公司,性价比高有哪家?

随着抖音平台流量红利的持续释放,越来越多企业意识到布局抖音营销的重要性,但缺乏专业团队、运营经验不足等问题让不少企业望而却步,选择抖音代运营公司成为高效破局的关键。然而,市场上抖音代运营公司良莠不齐,企…

聊聊多层压瓦机品牌制造商,这些靠谱企业值得关注

2025年建筑金属加工行业智能化转型加速,高效节能的压瓦设备已成为工业厂房、民用建筑、市政工程等场景提升施工效率、控制成本的核心支撑。无论是多功能集成的多层压瓦机、定制化冷弯成型解决方案,还是全周期售后保障…

2026年国内评价高的投影机出租厂家哪家强,激光投影机出租/20000流明投影机出租,投影机出租厂家联系电话

随着国内展览、演出、会议等活动的规模与频次持续攀升,投影机作为视听效果的核心载体,其租赁需求呈现爆发式增长。据行业数据显示,2025年国内投影机租赁市场规模已突破120亿元,年复合增长率达18%。然而,市场分散、…

2026年湖南智能矿山企业排名,源头智能矿山厂家哪家性价比高

本榜单依托全维度市场调研与真实行业口碑,深度筛选出五家源头智能矿山厂家,为矿山企业选型提供客观依据,助力精准匹配适配的服务伙伴。 TOP1 推荐:长沙迪迈科技股份有限公司 推荐指数:★★★★★ | 口碑评分:国内…

2026年大力推荐AI搜索优化公司,价格与服务对比给你参考

在AI营销浪潮席卷全球的当下,如何抢占AI对话平台这一新兴流量高地,成为企业突破获客瓶颈的关键。面对市场上良莠不齐的服务商,选择一家口碑不错的AI搜索优化专业公司,直接决定了企业能否精准捕捉AI时代的流量红利。…

深度测评9个AI论文网站,专科生搞定毕业论文格式规范!

深度测评9个AI论文网站&#xff0c;专科生搞定毕业论文格式规范&#xff01; AI 工具如何改变论文写作的未来 在当今数字化浪潮中&#xff0c;AI 工具正以前所未有的速度渗透到各个领域&#xff0c;尤其是在学术写作方面&#xff0c;其影响力日益凸显。对于专科生而言&#xff…

2026年复古地坪漆技术力榜单:从原料到落地的3大维度筛选真正实力派

2026年复古地坪漆技术力榜单:从原料到落地的3大维度筛选真正实力派 复古地坪正从“小众审美”走向“场景刚需”——无论是文创园的工业风走廊、咖啡馆的做旧水泥地,还是高端住宅的仿石纹客厅,消费者对“好看且耐用…

新一代Java应用日志可视化与监控强大的系统开源啦

新一代Java应用日志可视化与监控强大的系统开源啦pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas",…

2026成都合同纠纷律所推荐榜

2026成都合同纠纷律所推荐榜行业背景与需求洞察据《2026年中国法律服务市场白皮书》统计,2026年全国合同纠纷案件量同比增长16.8%,四川地区案件占西南地区总量的31.7%,其中成都作为省会城市,案件量占全省的45.2%。…

2026绵阳优质阳台柜定制品牌推荐:绵阳智能家居定制/绵阳木斯特全屋定制/绵阳榻榻米定制/绵阳橱柜定制/绵阳浴室柜定制/选择指南

2026绵阳优质阳台柜定制品牌推荐行业背景与推荐依据据《2026-2030中国全屋定制行业发展白皮书》数据显示,近年来国内阳台空间定制需求年复合增长率达18.7%,其中绵阳地区改善型住房的阳台柜定制需求占比超62%。随着二…

查找卧龙电驱加工设备先进的厂家,靠谱的有哪些推荐?

在工业自动化与新能源产业快速发展的当下,企业对电机设备的依赖程度日益加深,而电机的稳定运行直接关系到生产线的效率与企业的经济效益。因此,选择一家可靠的卧龙电驱供应商成为众多企业采购决策中的关键一环,其中…