LeetCode 377.组合总和IV

题目

给你一个由 不同 整数组成的数组 nums ,和一个目标整数 target 。请你从 nums 中找出并返回总和为 target 的元素组合的个数。(nums中的元素可以重复使用)

题目数据保证答案符合 32 位整数范围。

思路

本质上是 70. 爬楼梯,每次从 nums 中选一个数,作为往上爬的台阶数,计算爬 target 个台阶有多少种方案。70 那题相当于 nums=[1,2],因为每次只能爬 1 个或 2 个台阶。

代码

java 复制代码
class Solution {
    public int combinationSum4(int[] nums, int target) {
        int[] memo = new int[target + 1];
        Arrays.fill(memo, -1);
        return dfs(target, nums, memo);
    }

    private int dfs(int i, int[] nums, int[] memo) {
        if (i == 0) {
            return 1;
        }
        if (memo[i] != -1) {
            return memo[i];
        }
        int total = 0;
        for (int num : nums) {
            if (num <= i) {
                total += dfs(i - num, nums, memo);
            }
        }
        memo[i] = total;
        return memo[i];
    }
}

性能

相关推荐
样例过了就是过了几秒前
LeetCode热题100 全排列
数据结构·c++·算法·leetcode·dfs
2401_898075121 分钟前
分布式系统监控工具
开发语言·c++·算法
程序员夏末8 分钟前
【LeetCode | 第六篇】算法笔记
笔记·算法·leetcode
OKkankan25 分钟前
撕 STL 系列:封装红黑树实现 mymap 和 myset
java·c++·算法
xh didida30 分钟前
数据结构--实现链式结构二叉树
c语言·数据结构·算法
ab15151730 分钟前
3.15二刷基础90、105、106、110
数据结构·c++·算法
C蔡博士31 分钟前
最近点对问题(Closest Pair of Points)
java·python·算法
白太岁33 分钟前
算法:链表:指针变化与环
数据结构·算法·链表
寻寻觅觅☆33 分钟前
东华OJ-进阶题-10-分解质因数(C++)
数据结构·c++·算法
Darkwanderor39 分钟前
数据结构——ST表和RMQ问题
数据结构·c++·动态规划·st表·rmq问题