当前位置: 首页 > news >正文

历年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.jsqmd.com/news/307785/

相关文章:

  • 来学学大模型最新「合金特工」骚操作,能力比肩多智能体,AI 黑客成功率飙升
  • 大模型上下文工程(Context Engineering)详解,小白也能轻松学会!
  • Flutter Bloc 状态管理深度解析与开源鸿蒙 ArkUI 对标分析 - 详解
  • 吃出的爱意
  • 带你真正了解什么是 I/O 多路复用(附 Java + Spring Boot 实战案例)
  • 蓝牙基础(十):蓝牙串口、文件传输、通话控制
  • XSS攻击进阶:攻击链路、绕过技巧与企业级防护方案
  • 聊聊低温减速机供应商,鑫钺传动江苏服务性价比哪家高
  • 分析用工风险律师,靠谱的律所都有哪些
  • 聊聊宁德抖音代运营公司,性价比高有哪家?
  • 聊聊多层压瓦机品牌制造商,这些靠谱企业值得关注
  • 2026年国内评价高的投影机出租厂家哪家强,激光投影机出租/20000流明投影机出租,投影机出租厂家联系电话
  • 2026年湖南智能矿山企业排名,源头智能矿山厂家哪家性价比高
  • 2026年大力推荐AI搜索优化公司,价格与服务对比给你参考
  • 深度测评9个AI论文网站,专科生搞定毕业论文格式规范!
  • 2026年复古地坪漆技术力榜单:从原料到落地的3大维度筛选真正实力派
  • 新一代Java应用日志可视化与监控强大的系统开源啦
  • 2026成都合同纠纷律所推荐榜
  • 2026绵阳优质阳台柜定制品牌推荐:绵阳智能家居定制/绵阳木斯特全屋定制/绵阳榻榻米定制/绵阳橱柜定制/绵阳浴室柜定制/选择指南
  • 查找卧龙电驱加工设备先进的厂家,靠谱的有哪些推荐?
  • 2026年气动烫金机优质厂家排名,大山铭机械值得关注
  • 百纳互动网络公司概况全解析,福建地区口碑好的营销公司排名
  • 分析性价比高的GEO优化企业排名,杭州有哪些公司上榜
  • 2026琉璃瓦成型设备品牌商排名,靠谱的厂家大盘点
  • 2026年云浮地区琉璃瓦成型设备推荐,哪家比较靠谱
  • 2026年进口地坪漆厂家十大排名深度解析:从技术壁垒到场景适配的品牌力较量
  • 2025假日欺诈:利用礼品卡与预付卡的技术分析
  • 好写作AI:毕业论文“引言”大比拼,我们派了个AI学霸去参赛
  • 好写作AI:论文修改,到底用AI是“真高效”还是“假勤奋”?我们用数据说话
  • 好写作AI:“学霸”和“学酥”用同一个AI,差距反而更大了?