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

GESP认证C++编程真题解析 | P10111 [GESP202312 七级] 纸牌游戏

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

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

适合人群:

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

附上汇总帖:GESP认证C++编程真题解析 | 汇总


【题目来源】

洛谷:[P10111 GESP202312 七级] 纸牌游戏 - 洛谷

【题目描述】

你和小杨在玩一个纸牌游戏。

你和小杨各有3 33张牌,分别是0 、 1 、 2 0、1、2012。你们要进行N NN轮游戏,每轮游戏双方都要出一张牌,并按1 11战胜0 002 22战胜1 110 00战胜2 22的规则决出胜负。第i ii轮的胜者可以获得2 × a i 2 \times a_i2×ai分,败者不得分,如果双方出牌相同,则算平局,二人都可获得a i a_iai( i = 1 , 2 , ⋯ , N ) (i=1,2,\cdots,N)(i=1,2,,N)

玩了一会后,你们觉得这样太过于单调,于是双方给自己制定了不同的新规则。小杨会在整局游戏开始前确定自己全部n nn轮的出牌,并将他的全部计划告诉你;而你从第2 22轮开始,要么继续出上一轮出的牌,要么记一次“换牌”。游戏结束时,你换了t tt次牌,就要额外扣b 1 + ⋯ + b t b_1+\cdots+b_tb1++bt分。

请计算出你最多能获得多少分。

【输入】

第一行一个整数N NN,表示游戏轮数。

第二行N NN个用单个空格隔开的非负整数a 1 , ⋯ , a N a_1,\cdots,a_Na1,,aN,意义见题目描述。

第三行N − 1 N-1N1个用单个空格隔开的非负整数b 1 , ⋯ , b N − 1 b_1,\cdots,b_{N-1}b1,,bN1,表示换牌的罚分,具体含义见题目描述。由于游戏进行 N 轮,所以你至多可以换N − 1 N-1N1次牌。

第四行N NN个用单个空格隔开的整数c 1 , ⋯ , c N c_1,\cdots,c_Nc1,,cN,依次表示小杨从第1 11轮至第N NN轮出的牌。保证c i ∈ 0 , 1 , 2 c_i\in{0,1,2}ci0,1,2

【输出】

一行一个整数,表示你最多获得的分数。

【输入样例】

4 1 2 10 100 1 100 1 1 1 2 0

【输出样例】

219

【算法标签】

《洛谷 P10111 纸牌游戏》 #动态规划DP# #GESP# #2023#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=1005;// 最大轮数intn;// 总轮数intans=-1e9;// 最终答案inta[N],b[N],c[N];// a: 每轮基础得分, b: 换牌代价, c: 每轮出牌类型intdp[N][N][3];// dp[i][j][k]: 前i轮换了j次牌,第i轮出牌类型为k的最大得分// 计算在第pos轮,上次出牌类型x,本次出牌类型y的得分intcalc(intx,inty,intpos){if(x==y)// 两次出牌类型相同{returna[pos];// 得a[pos]分}if(x==0)// 上次出石头{if(y==1)// 这次出布{return0;// 平局}else// 这次出剪刀{return2*a[pos];// 获胜}}elseif(x==1)// 上次出布{if(y==0)// 这次出石头{return2*a[pos];// 获胜}else// 这次出剪刀{return0;// 平局}}else// 上次出剪刀{if(y==0)// 这次出石头{return0;// 平局}else// 这次出布{return2*a[pos];// 获胜}}}intmain(){// 输入cin>>n;for(inti=1;i<=n;i++)// 每轮基础得分{cin>>a[i];}for(inti=1;i<n;i++)// 第i次换牌的代价{cin>>b[i];}for(inti=1;i<=n;i++)// 第i轮必须出的牌型{cin>>c[i];}// 初始化dp为极小值memset(dp,0,sizeof(dp));// 实际为0,但代码中未显示初始化// 动态规划for(inti=1;i<=n;i++)// 枚举轮数{for(intj=0;j<i;j++)// 枚举换牌次数{for(intk=0;k<=2;k++)// 枚举当前轮实际出牌类型{// 计算当前轮得分intx=calc(k,c[i],i);// 不换牌的情况dp[i][j][k]=dp[i-1][j][k]+x;// 如果j=0,不能换牌if(j==0)continue;// 逻辑检查:第i轮最多换i-1次牌if(j==i-1){dp[i][j][k]=-1e9;// 标记为不可能}// 换牌的情况if(k==0)// 当前出石头{dp[i][j][k]=max(dp[i][j][k],max(dp[i-1][j-1][1],dp[i-1][j-1][2])-b[j]+x);}elseif(k==1)// 当前出布{dp[i][j][k]=max(dp[i][j][k],max(dp[i-1][j-1][0],dp[i-1][j-1][2])-b[j]+x);}else// 当前出剪刀{dp[i][j][k]=max(dp[i][j][k],max(dp[i-1][j-1][0],dp[i-1][j-1][1])-b[j]+x);}}}}// 找最大值for(inti=0;i<n;i++){ans=max({ans,dp[n][i][0],dp[n][i][1],dp[n][i][2]});}// 输出结果cout<<ans<<endl;return0;}

【运行结果】

4 1 2 10 100 1 100 1 1 1 2 0 219
http://www.jsqmd.com/news/129612/

相关文章:

  • 2025初中数学家教五大机构权威评测,目标中考高分的初中数学家教 - 速递信息
  • 开源AI神器Open-AutoGLM发布(AutoGLM技术内幕首次公开)
  • 如何在macOS上高效运行Open-AutoGLM?资深AI工程师的7条实战建议
  • 孩子王闯关港股:背水一战
  • Open-AutoGLM评分全网最高(三大核心指标领先第二名30%)
  • 企业级知识管理平台如何用anything-llm镜像实现?
  • 2025国内最新补血营养剂品牌TOP5评测!中华老字号与现代科技融合,国内优质厂家权威榜单发布 - 全局中转站
  • 智能测试用例生成:是效率革命,还是维护噩梦?
  • Spring 事务失效
  • 亲测!优质服务器数据恢复中心实践分享
  • 2025年质量好的胶木球厂家推荐及选购指南 - 品牌宣传支持者
  • 2025年知名的钢珠轨/反弹钢珠轨厂家最新热销排行 - 品牌宣传支持者
  • 2025年12月欧洲名义雇主eor人力解决方案,全球灵活用工名义雇主eor方案,名义雇主eor公司推荐:行业测评与选择指南 - 品牌鉴赏师
  • 测试数据生成的“智变”:利用AIGC快速构建复杂、合规的测试数据。
  • 2025年口碑好的景观照明工程工程案例榜单 - 品牌宣传支持者
  • 2025年AI大模型学习之路:产品经理面试攻略+全套学习资料,小白也能轻松入门_真心劝大家转行AI产品经理
  • 亲测勒索病毒解密数据恢复技术标准
  • 北京新加坡国际学校:两类优质选择(课程体系、参考学费、核心特点) - 速递信息
  • 为什么顶尖团队都在抢着部署Open-AutoGLM?本地实践揭示惊人效率提升
  • 基于C#实现串口调试工具读取温度值
  • 【AI插件革命】:Open-AutoGLM为何成为企业智能化转型新宠?
  • 产品经理转AI产品经理:5步转行指南+2万学习资源免费送_如何从传统产品经理转行成为顶尖的AI产品经理?
  • 变压器的智能绕线功能系统
  • 2025年评价高的包装书刊印刷/广告书刊印刷客户好评推荐榜 - 品牌宣传支持者
  • 基于单片机的智能窗帘控制系统设计
  • 2025年靠谱的缓冲托底轨行业内口碑厂家排行榜 - 品牌宣传支持者
  • 阿里云+智普Open-AutoGLM部署实录(万字长文揭秘企业级AI落地细节)
  • Open-AutoGLM智能体电脑配置全解析:新手避坑指南与最佳实践
  • 2025年度热工装备企业排名:株洲诺天科技实力怎样? - 工业品牌热点
  • Open-AutoGLM模型服务搭建全记录(从零到生产环境落地)