当前位置: 首页 > 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.rkmt.cn/news/142220.html

相关文章:

  • 企业级知识管理平台如何用anything-llm镜像实现?
  • 2025年AI大模型学习之路:产品经理面试攻略+全套学习资料,小白也能轻松入门_真心劝大家转行AI产品经理
  • 2025年知名的钢珠轨/反弹钢珠轨厂家最新热销排行 - 品牌宣传支持者
  • 亲测!优质服务器数据恢复中心实践分享
  • 2025年质量好的胶木球厂家推荐及选购指南 - 品牌宣传支持者
  • 北京新加坡国际学校:两类优质选择(课程体系、参考学费、核心特点) - 速递信息
  • 为什么顶尖团队都在抢着部署Open-AutoGLM?本地实践揭示惊人效率提升
  • 基于C#实现串口调试工具读取温度值
  • 【AI插件革命】:Open-AutoGLM为何成为企业智能化转型新宠?
  • 2025年评价高的包装书刊印刷/广告书刊印刷客户好评推荐榜 - 品牌宣传支持者
  • Open-AutoGLM智能体电脑配置全解析:新手避坑指南与最佳实践
  • 2025年度热工装备企业排名:株洲诺天科技实力怎样? - 工业品牌热点
  • Open-AutoGLM权限管理与安全配置(生产环境必知的6大要点)
  • 展示架设计工作室哪家好?展示架生产企业选择哪家好? - 工业推荐榜
  • 2025年卫生纸加工设备核心性能深度评测报告:卫生纸抽纸加工设备、大型卫生纸加工设备、小型抽纸加工设备、软抽纸加工设备 - 优质品牌商家
  • 基于单片机的电子秤设计
  • 深入理解RAG索引:构建高效大模型检索系统的核心
  • 还在手动调参?Open-AutoGLM让AI自动优化,效率飙升90%!
  • 2025年12月热门文昌塔厂家推荐适配家庭学校企业 - 优质品牌商家
  • 如何在3小时内完成智谱Open-AutoGLM部署?一线架构师亲授加速秘技
  • 2025年行业内主动边坡防护网厂家最新权威推荐排行榜 - 行业平台推荐
  • 2克拉钻戒品牌推荐:价值体系解构与高端选购指南 - 博客万
  • 云原生领域 Chart 的关键组件介绍
  • 2025年新能源客车选购推荐:宇通客车引领绿色出行新风尚,客车、校车、轻客、旅游客车全面涵盖 - 深度智识库
  • 想找工业级串口屏,不妨看看恒域威高性能7寸串口屏
  • 2025年推荐冰淇淋风味酸奶排行、适合老人的爆珠风味酸奶推荐年度排名 - mypinpai
  • w金属一般用在芯片的哪个支撑?用什么方法做的?
  • 【IC】英伟达显卡的超高显存带宽
  • FreeBuds SE4 ANC 连接没弹窗?其实是连接方式的小细节
  • 2025年天然木皮供应商权威推荐榜单:尤加利木皮/卡丝楠木皮/黑胡桃木皮源头厂家精选 - 品牌推荐官