【DP】第十三届蓝桥杯省赛C++ B组《李白打酒加强版》(C++)
【题目描述】
话说大诗人李白,一生好饮。
幸好他从不开车。
一天,他提着酒壶,从家里出来,酒壶中有酒 2 斗。
他边走边唱:
无事街上走,提壶去打酒。
逢店加一倍,遇花喝一斗。
这一路上,他一共遇到店 N 次,遇到花 M 次。
已知最后一次遇到的是花,他正好把酒喝光了。
请你计算李白这一路遇到店和花的顺序,有多少种不同的可能?
注意:壶里没酒 (0 斗) 时遇店是合法的,加倍后还是没酒;但是没酒时遇花是不合法的。
【输入格式】
第一行包含两个整数 N 和 M。
【输出格式】
输出一个整数表示答案。由于答案可能很大,输出模 1000000007 的结果。
【数据范围】
对于 40% 的评测用例:1≤N,M≤10。
对于 100% 的评测用例:1≤N,M≤100。
【输入样例】
5 10
【输出样例】
14
【样例解释】
如果我们用 0 代表遇到花,1 代表遇到店,14 种顺序如下:
010101101000000
010110010010000
011000110010000
100010110010000
011001000110000
100011000110000
100100010110000
010110100000100
011001001000100
100011001000100
100100011000100
011010000010100
100100100010100
101000001010100
【思路】
关键是酒的数量不可能多于遇到花的次数,否则不可能喝光酒。
状态表示:f[i][j][k],i 表示当前遇到店的数量、j 表示当前遇到花的数量,k 表示当前酒的数量。
状态属性:当前所有数量的集合。
状态表示:当前f[i][j][k]刚遇到店还是刚遇到花,f[i][j][k] = f[i-1][j][k/2] + f[i][j-1][k+1]
【代码】
#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;const int N = 110, MOD = 1e9 + 7;int n, m;
int f[N][N][N];int main()
{cin >> n >> m;//初始状态:没遇到店和花,有2斗酒f[0][0][2] = 1;for (int i = 0; i <= n; i ++ )for (int j = 0; j <= m; j ++ )for (int k = 0; k <= m; k ++ ){//把当前值赋给变量是为了代码简洁,需要加上 & 才能保证取出原数组中元素的地址。int& v = f[i][j][k];//刚遇到的是店,需要判断 i >= 1 并且花是偶数if (i && k % 2 == 0) v = (v + f[i - 1][j][k / 2]) % MOD;//刚遇到的是花,需要判断 j >= 1if (j) v = (v + f[i][j - 1][k + 1]) % MOD;}//最后的状态即为遇到花后,酒刚好喝完。cout << f[n][m - 1][1] << endl;return 0;
}相关文章:
【DP】第十三届蓝桥杯省赛C++ B组《李白打酒加强版》(C++)
【题目描述】 话说大诗人李白,一生好饮。 幸好他从不开车。 一天,他提着酒壶,从家里出来,酒壶中有酒 2 斗。 他边走边唱: 无事街上走,提壶去打酒。 逢店加一倍,遇花喝一斗。 这一路上&am…...
数据结构试卷第九套
1.时间复杂度 2.树,森林,二叉树的转换 2.1树转二叉树 给所有的兄弟节点之间加一条连线;去线,只保留当前根节点与第一个叶子节点的连线,删除它与其他节点之间的连线;然后根据左孩子右兄弟进行调整…...
【Linux第三课-基础开发工具的使用】yum、vim、gcc/g++编译器、gdb、Make/Makefile编写、进度条程序、git命令行简单操作
目录 yum - 软件包管理器快速认识yum快速使用yumyum搜索yum安装yum卸载 yum的周边 - yum的整个生态问题 vim快速介绍vimvim的模式命令模式插入模式低行模式 常见模式 -- 命令、低行命令模式 -- 光标的移动命令模式 -- 复制粘贴、剪贴、删除命令模式 -- 小写/大写替换模式命令模…...
Redis:ClassCastException【bug】
Redis:ClassCastException【bug】 前言版权Redis:ClassCastException【bug】错误产生相关资源控制器:UserController("/user")配置:RedisConfiguration实体类:User数据表:User 解决 最后 前言 2…...
JSON 配置文件
JSON 配置文件的作用 JSON 是一种数据格式,在实际开发中, JSON 总是以配置文件的形式出现。小程序项目中也不例外:通过不同的 .json 配置文件,可以对小程序项目进行不同级别的配置。 小程序项目中有 4 种 json 配置文件࿰…...
由浅到深认识Java语言(6):控制流程语句
该文章Github地址:https://github.com/AntonyCheng/java-notes 在此介绍一下作者开源的SpringBoot项目初始化模板(Github仓库地址:https://github.com/AntonyCheng/spring-boot-init-template & CSDN文章地址:https://blog.c…...
lv17 安防监控项目实战 3
代码目录 框架 our_storage 编译最终生成的目标文件obj 编译生成中间的.o文件 data_global.c 公共资源定义(使用在外extern即可)定义了锁定义了条件变量消息队列id、共享内存id、信号量id及key值发送短信、接收短信的号码向消息队列发送消息的函数&am…...
文本处理基本方法
目录 分词 jieba 词性标注 😆😆😆感谢大家观看😆😆😆 分词 在中文文本中,由于词与词之间没有明显的界限符,如英文中的空格,因此分词是中文自然语言处理的一个基础且…...
Java面试题(Spring篇)
💟💟前言 友友们大家好,我是你们的小王同学😗😗 今天给大家打来的是 Java面试题(Spring篇) 希望能给大家带来有用的知识 觉得小王写的不错的话麻烦动动小手 点赞👍 收藏⭐ 评论📄 小王的主页…...
操作系统:malloc与堆区内存管理
malloc是函数而不是系统调用,他的底层是同调调用brk和mmap这两个系统调用实现功能的,具体选择brk还是mmap要看申请的空间大小以及malloc中的阈值(一般是128kb) 注意申请的空间只有使用才会触发缺页中断映射到物理内存 不理解的话先…...
javaSwing推箱子游戏
一、简介 策略性游戏可以锻炼人的思维能力还能缓解人的压力,使人们暂时忘却生活当中的烦恼,增强人们的逻辑思维能力,游戏的艺术美也吸引着越来越多的玩家和厂商,寓教于乐,在放松人们心情的同时还可以活跃双手。在人类…...
JAVA多线程之JMM
文章目录 1. Java内存模型2. 内存交互3. 三大特性3.1 可见性3.1.1 可见性问题3.1.2 原因3.1.3 解决方法 3.2 原子性3.3 有序性 4. 指令重排5. JMM 与 happens-before5.1 happens-before关系定义5.2 happens-before 关系 在继续学习JUC之前,我们现在这里介绍一下Java…...
Windows10 专业版 系统激活
Windows10 专业版 系统激活 参考: Windows10系统激活技巧 第一步:在电脑桌面,新建一个文本文档 第二步:打开文本文档,输入以下代码后,直接保存关闭文档 slmgr/skms kms.03k.org slmgr/ato 第三步࿱…...
C#使用LINQ和EF Core
在实际应用中,您可以使用 LINQ 查询 EF Core 来执行各种数据库操作。通过 LINQ,您可以轻松地过滤、排序、分组和连接数据。 要使用LINQ查询EF Core中的数据,您可以按照以下步骤进行操作: 首先,确保您已经安装了 Entit…...
数字人解决方案— SadTalker语音驱动图像生成视频原理与源码部署
简介 随着数字人物概念的兴起和生成技术的不断发展,将照片中的人物与音频输入进行同步变得越来越容易。然而,目前仍存在一些问题,比如头部运动不自然、面部表情扭曲以及图片和视频中人物面部的差异等。为了解决这些问题,来自西安…...
HTML5语法总结
文章目录 一.HTML基本框架二.标题标签三.段落标签四.换行与水平线标签五.文本格式化标签(加粗、倾斜、下划线、删除线)六.图像标签扩展:相对路径,绝对路径与在线网址 七.超链接标签八.音频标签九.视频标签十.列表标签十一.表格标签扩展:表格结构标签合并…...
在github下载的神经网络项目,如何运行?
github网页上可获取的信息 在github上面,有一个requirements.txt文件,该文件说明了项目要求的python解释器的模块。 - 此外,还有一个README.md文件,用来说明项目的运行环境以及其他的信息。例如python解释器的版本是3.7、PyTorc…...
spring boot学习第十四篇:使用AOP编程
一、基本介绍 1,什么是 AOP (1)AOP 为 Aspect Oriented Programming 的缩写,意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术。 (2)利用 AOP…...
凯特信安云签解决方案
联合解决方案 凯特信安基于《电子签名法》设计“云签服务方案”,应用人脸识别、电子签章签名云服务等技术,支持多个自然人、多个企业等签名,满足各种移动终端签署的应用场景。面向不动产登记、工改系统等社会公众服务系统,针对自然…...
【xr806开发板使用】连接wifi例程实现
##开发环境 win10 WSL ##1、环境配置 参考:https://aijishu.com/a/1060000000287513 首先下载安装wsl 和ubuntu https://docs.microsoft.com/zh-cn/windows/wsl/install (1)安装repo: 创建repo安装目录: mkdir ~/…...
别再调Prompt了!SITS2026圆桌重磅共识:下一代智能生成将绕过自然语言,直连IDE AST与编译器IR(附3家头部厂商技术路线图)
第一章:SITS2026圆桌:智能代码生成趋势 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026圆桌论坛上,来自GitHub、Tabnine、DeepMind与国内大模型开源社区的七位核心研发者共同指出:智能代码生成正从“单轮补全”迈向“…...
Win11升级翻车实录:从TPM报错到桌面黑屏,我遇到的坑和解决办法都在这了
Windows 11升级避坑指南:从硬件检查到系统优化的完整方案 最近身边不少朋友都在讨论Windows 11的新界面和功能,但升级过程却并非一帆风顺。作为一个经历过完整升级流程的用户,我想分享一些实战经验,帮助大家避免常见的"翻车…...
物联网LoRa系列-18:Sx1262射频信号放大器与电源管理的协同设计
1. Sx1262射频信号放大器的核心作用 第一次拿到Sx1262芯片规格书时,我被它内部集成的射频信号放大器惊艳到了。这个火柴盒大小的芯片里,竟然藏着能推动500米无线通信的"能量引擎"。功率放大器(PA)和低噪声放大器&#…...
Anthropic发布Claude Opus 4.7:性能显著提升,多项测评领先,多方面功能更新
Anthropic发布Claude Opus 4.7:性能显著提升,多项测评领先,多方面功能更新智东西4月17日报道,昨天夜间,Anthropic发布新一代旗舰大模型Claude Opus 4.7。该模型在高级软件工程、高分辨率图像处理能力方面显著提升&…...
解读核心Maintainer观点|Presto 不只是版本升级!从查询引擎到湖仓执行层,AI Infra 新方向
最近看了InfoQ上的一篇文章《Presto 的再定位:从查询引擎到下一代数据湖执行层》,了解了从核心Maintainer视角观察到的Presto及整个数据基础设施行业范式的迁移,深有感触。对于做数据开发、湖仓架构或AI工程的同学来说,Presto的这…...
清音刻墨Qwen3进阶技巧:参数调整与批量处理功能详解
清音刻墨Qwen3进阶技巧:参数调整与批量处理功能详解 1. 引言:从基础到进阶 如果你已经体验过清音刻墨Qwen3字幕对齐系统的基础功能,可能会惊叹于它"字字精准,秒秒不差"的自动对齐能力。但这款基于Qwen3-ForcedAligner…...
GEMINI编代码时输不出iloc[0]
这是我的对话记录,有没有大佬能帮帮我#你生成一行包括iloc[0],的python代码以下是包含 iloc, 的 Python 代码示例。在 pandas (Python Data Analysis Library) 中,这种语法通常用于提取数据并隐式构建单元素元组 (Tuple):Pythonfirst_record_…...
PostgreSQL vs PolarDB:Checkpoint 调优策略深度对比(高频 vs 低频)
在一次 PostgreSQL 性能排查中,我遇到了这样一段日志:checkpoints are occurring too frequently (29 seconds apart) HINT: Consider increasing the configuration parameter "max_wal_size".而另一边,在 PolarDB 文档/实践中却看…...
AI编程革命:用Codex告别重复造轮子
告别重复造轮子:Codex写脚本的技术文章大纲技术背景与现状重复造轮子的定义及其在开发中的常见场景 传统脚本编写方式的痛点:效率低、维护成本高 AI辅助编程工具(如Codex)的兴起及其技术原理Codex的核心能力与应用场景Codex的模型…...
如何实现跨设备音频共享?Scream虚拟声卡网络传输终极指南
如何实现跨设备音频共享?Scream虚拟声卡网络传输终极指南 【免费下载链接】scream Virtual network sound card for Microsoft Windows 项目地址: https://gitcode.com/gh_mirrors/sc/scream 你是否曾想过将电脑音频无线传输到其他设备播放?无论是…...
