2023年蓝桥杯大学A组第二题:有奖问答(一维动态规划解法)

embedded/2024/10/18 23:24:06/

题目描述


小蓝正在参与一个现场问答的节目。
活动中一共有 30 道题目,每题只有答对和答错两种情况,每答对一题得 10 分,答错一题分数归零。
小蓝可以在任意时刻结束答题并获得目前分数对应的奖项,之后不能再答任何题目。
最高奖项需要 100 分,所以到达 100 分时小蓝会直接停止答题。
已知小蓝最终实际获得了 70 分对应的奖项,请问小蓝所有可能的答题情况有多少种?
本题的结果为一个整数,在提交答案时只输出这个整数,输出多余的内容将无法得分。

解题思路

根据题目可知,在题目数≥8题时,最后8题一定是【×+8√】,只需考虑除最后8题前面题目的作答情况。

考虑一维动态规划,f[i]定义为i个题时,小蓝获得70分的答题情况的种类数,状态转移过程可以表示为,从i-1道题到i道题过程中,最前面的题作答是√还是×,若不考虑任何条件,则f[i]=2f[i-1],即每多一道题,前面的题可以是两种情况,相乘即可。

初始状态:f[7]=1(全对),f[8]=1,考虑到100分会直接停止,在i=8到17的过程中,除最后8题,前面的题不可能出现得100分的情况,故f[i]=2f[i-1]。

i=18时,若最前面的题为√,则会出现100分的情况,故f[18]=2*f[17]-1

i=19时,i=18包含【9√+x+x+9√】的情况,此时若最前面的题为√,则会直接停止,f[19]=2*f[18]-1

考虑前面9题均为√的情况,可以推得i=19到i=28时,状态转移方程为f[i]=2f[i-1]-2^(i-19)

i=29,需考虑i=28时存在【9√+x+10√+×+9√】情况,同理i=30需考虑i=29的特殊情况。

最后将f[7]~f[30]进行相加得到答案:8335366

代码

#include<bits/stdc++.h>
using namespace std;
int main() {vector<int> f(31, 0);f[7] = 1;f[8] = 1;for (int i = 9; i < 18; i++)f[i] = 2 * f[i - 1];f[18] = 2 * f[17] - 1;int t = 1;for (int i = 19; i <= 28; i++){f[i] = 2 * f[i - 1]-t;t *= 2;}f[29] = 2 * f[28] - (t - 1);t *= 2;f[30] = 2 * f[29] - (t - 3);int sum = 0;for (int i = 7; i <= 30; i++) {sum += f[i];}cout << sum;return 0;
}


http://www.ppmy.cn/embedded/29084.html

相关文章

微信小程序 - 登录(切屏后继续倒计时)

屏幕休眠或后台运行倒计时暂停问题 updateTime: function () {let promise new Promise((resolve, reject) > {var beginTime new Date().getTime();let setTimer setInterval(() > {var newTime new Date().getTime();var dTime (newTime - beginTime) / 1000;dTim…

Node私库Verdaccio使用记录,包的构建,推送和拉取

Node私库Verdaccio使用记录&#xff0c;包的构建&#xff0c;推送和拉取 Verdaccio是一个轻量级的私有npm代理注册中心&#xff0c;它可以帮助你在本地搭建一个npm仓库&#xff0c;非常适合企业内部使用。通过使用Verdaccio&#xff0c;你可以控制和缓存依赖包&#xff0c;提高…

c语言从入门到函数速成(1)

温馨提醒&#xff1a;本篇文章适合人群&#xff1a;刚学c又感觉那个地方不怎么懂的同学以及以及学了一些因为自身原因停学一段时间后又继续学c的同学 好&#xff0c;正片开始。 主函数 学c时最先学的是我们c语言程序的主体函数&#xff0c;c的主函数有两种写法&#xff0c;这…

速盾:什么是cdn架构

CDN&#xff08;Content Delivery Network&#xff09;即内容分发网络&#xff0c;是一种分布式的架构&#xff0c;用于提高互联网上的内容传输速度和用户体验。CDN架构通过将内容分发到全球多个节点&#xff0c;使用户能够从最近的节点获取内容&#xff0c;从而减少延迟和网络…

【上岗认证】错题整理记录

目录 &#x1f31e;一、阶段1&#xff1a;编码规范 &#x1f30a;编码规范考试-CC &#x1f31e;二、阶段2&#xff1a;开发基础 &#x1f30a;C/C &#x1f30a;数据库&#xff08;Oracle/MySql&#xff09; &#x1f31e;三、阶段3&#xff1a;测试基础 &#x1f30a;…

富格林:正规本领防卫诱导欺诈风险

富格林悉知&#xff0c;现货黄金投资吸引不少的投资者进入市场&#xff0c;不过投资者在进入市场之前需要了解市场存在的风险&#xff0c;做好正规预防避免诱导欺诈导致亏损情况。在黄金投资中&#xff0c;降低欺诈受骗的风险是投资者必须要做的&#xff0c;那么降低风险有什么…

golang调用钉钉发送群机器人消息

golang调用钉钉发送群机器人消息 因为当时用的wire依赖注入&#xff0c;所以需要用多个钉钉机器人的时候&#xff0c;就把每个client实例加入到了map里 package dingtype Client interface {// SendMessage 发送钉钉SendMessage(s string, at ...string) error }type ClientO…

基于SpringBoot+Vue的旅游网站系统

初衷 在后台收到很多私信是咨询毕业设计怎么做的&#xff1f;有没有好的毕业设计参考?能感觉到现在的毕业生和当时的我有着同样的问题&#xff0c;但是当时的我没有被骗&#xff0c;因为现在很多人是被骗的&#xff0c;还没有出学校还是社会经验少&#xff0c;容易相信别人。…