【Leetcode每日一题】「动态规划」1155.掷骰子等于目标和的方法数

文章目录

思路

首先一一眼看就是一个动态规划问题;那就用dp做

有哪些变量呢,有:掷骰子的数目,达到target的种数,掷骰子的和,和每次掷骰子的数目。

1.确定dp数组如何确立:答案要求返回的是达到target的种数那么我们的这个dp数组代表的就是达到target的种数,还有现在在掷那个骰子和当前掷骰子的和需要表示,那么我们的dp数组就要这么设计:dp当前在掷那个骰子当前掷骰子的和=达到这个和的种数;

2.确定答案要返回什么:要反返回掷完骰子达到的种数:也就是返回:return dpntarget;

  1. dp数组初始化:先归零memset(dp,0,sizeof(dp));然后确定初始值:dp00第0个骰子的种数肯定就是1了; dp00=1;

  2. 确定dp推导公式:我们dp代表的是数量,l代表当前骰子投的数的话就是当前dpij可以达到的种数加上投l的种数dpi-1j-l的种数也就是: dpij=(dpij+dpi-1j-l);

  3. 注意要MOD1e9+7

代码如下:

cpp 复制代码
class Solution {
public:
    int numRollsToTarget(int n, int k, int target) {
                int dp[n+1][target+1];//dp结果为骰子种数;n为进行的第n个骰子,target为骰子的和
        memset(dp,0,sizeof(dp));
        dp[0][0]=1;
            for(int i =1;i<=n;i++){
            for(int j=1;j<=target;j++){
                for(int l=1;l<=k;l++){
                   if(l<=j){
                        dp[i][j]=(dp[i][j]+dp[i-1][j-l])%(int)(1e9+7);
                    } 
                }
           } 
        }  
            return dp[n][target];
    }
};

题目如下:

这里有 n 个一样的骰子,每个骰子上都有 k 个面,分别标号为 1 到 k 。

给定三个整数 n , k 和 target ,返回可能的方式(从总共 kn 种方式中)滚动骰子的数量,使正面朝上的数字之和等于 target 。

答案可能很大,你需要对 109 + 7 取模 。

示例 1:

输入:n = 1, k = 6, target = 3

输出:1

解释:你扔一个有 6 个面的骰子。

得到 3 的和只有一种方法。

示例 2:

输入:n = 2, k = 6, target = 7

输出:6

解释:你扔两个骰子,每个骰子有 6 个面。

得到 7 的和有 6 种方法:1+6 2+5 3+4 4+3 5+2 6+1。

示例 3:

输入:n = 30, k = 30, target = 500

输出:222616187

解释:返回的结果必须是对 109 + 7 取模。

提示:

1 <= n, k <= 30

1 <= target <= 1000

相关推荐
小欣加油2 小时前
leetcode56 合并区间
c++·算法·leetcode·职场和发展
lqqjuly2 小时前
前沿算法深度解析(二)
人工智能·算法·机器学习
徐小夕3 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
akunkuntaimei4 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld4 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
8Qi86 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
youngerwang7 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
KaMeidebaby7 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠8 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力8 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试