[蓝桥杯 2022 省 B] 李白打酒加强版

题目链接:

思路:

①定义dp数组,f[i][j][k],表示经过 i 店, 遇到 j 花, 还有 k 酒。如果酒的数量超过了花的数量,那么一定喝不完。因此,k 不能超过 M。

②从店推过来,f[i][j][k] += f[i-1][j][k/2],要保证 i-1 和 k/2 符合,所以 i >= 1 并且 k 能被2整除。

③从花推过来,f[i][j][k] += f[i][j-1][k+1],要保证 j-1 和 k+1 符合,所有 j >= 1并且 k >= -1(省略,k一定大于0)。

④题目规定最后一定遇到花,并且刚好喝完酒,因此,输出 f[n][m-1][1]。

代码:

cpp 复制代码
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int N = 110, MOD = 1e9+7;

int n, m;
//dp数组
//表示经过i家店 j躲花 还剩下 k 酒
int f[N][N][N];

signed main(){
    cin >> n >> m;
    //根据题意 初始化
    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++){
                //店
                if(i && (k%2==0)){
                    f[i][j][k] += f[i-1][j][k/2];
                    f[i][j][k] %= MOD;
                }
                if(j){
                    f[i][j][k] += f[i][j-1][k+1];
                    f[i][j][k] %= MOD;
                }
            }
        }
    }
    
    cout << f[n][m-1][1] << endl;
    return 0;
}
相关推荐
魂梦翩跹如雨12 小时前
P8615 [蓝桥杯 2014 国 C] 拼接平方数——Java解答
java·c语言·蓝桥杯
迈巴赫车主14 小时前
蓝桥杯20534爆破 java
java·数据结构·算法·职场和发展·蓝桥杯
是苏浙16 小时前
蓝桥杯备战day2
蓝桥杯
王老师青少年编程17 小时前
线性DP第12课:线性DP应用案例实践:数字三角形
c++·动态规划·dp·线性dp·csp·信奥赛·数字三角形
量子炒饭大师20 小时前
David自习刷题室——【蓝桥杯刷题备战】乘法表
c语言·c++·git·职场和发展·蓝桥杯·github·visual studio
_OP_CHEN20 小时前
【算法基础篇】(二十三)数据结构之并查集基础:从原理到实战,一篇吃透!
数据结构·算法·蓝桥杯·并查集·算法竞赛·acm/icpc·双亲表示法
良木生香2 天前
【程序设计】P8772 [蓝桥杯 2022 省 A] 求和
c语言·算法·职场和发展·蓝桥杯
_OP_CHEN2 天前
算法基础篇:(二十二)数据结构之单调队列:滑动窗口问题的 “最优解” 神器
数据结构·c++·算法·蓝桥杯·算法竞赛·单调队列·acm/icpc
谁刺我心3 天前
蓝桥杯C++常用STL
c++·算法·蓝桥杯
魂梦翩跹如雨3 天前
P8723 [蓝桥杯 2020 省 AB3] 乘法表——Java解答
java·蓝桥杯