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];
    }
}

性能

相关推荐
lifallen20 分钟前
Disruptor高性能基石:Sequence并发优化解析
java·数据结构·后端·算法
麦兜*30 分钟前
【算法】十大排序算法超深度解析,从数学原理到汇编级优化,涵盖 15个核心维度
java·汇编·jvm·算法·spring cloud·ai·排序算法
重生之我是Java开发战士36 分钟前
【C语言】深度剖析指针(三):回调机制、通用排序与数组指针逻辑
c语言·开发语言·算法
zjoy_223342 分钟前
[算法]Leetcode3487
java·学习·算法·leetcode
蒟蒻小袁1 小时前
力扣面试150题--只出现一次的数字II
算法·leetcode·面试
CHOTEST中图仪器1 小时前
三坐标测量机路径规划与补偿技术:如何用算法看见微米级误差?
算法·三坐标测量仪·三坐标测量机·精密测量技术
CoovallyAIHub1 小时前
数据集分享 | 稻田识别分割数据集、水稻虫害数据集
深度学习·算法·计算机视觉
朝朝又沐沐2 小时前
算法竞赛阶段二-数据结构(38)数据结构动态链表list
数据结构·算法·链表
死也不注释2 小时前
【在Unity游戏开发中Dictionary、List介绍】
数据结构·游戏·unity·游戏引擎·list·游戏程序
geovindu2 小时前
ArKTS:List 数组
数据结构·list·harmonyos