518 零钱对换II
给你一个整数数组 coins 表示不同面额的硬币,另给一个整数 amount 表示总金额。
请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额,返回 0 。
假设每一种面额的硬币有无限个。
题目数据保证结果符合 32 位带符号整数。
def change(amount:int,coins:'List[int]')->int:dp=[0]*(amount+1)dp[0]=1for i in range len(conins):for j in range(coins[i],amount+1):dp[j]+=dp[j-coins[i]]return dp[amount]
377 组合总和IV
给你一个由 不同 整数组成的数组 nums ,和一个目标整数 target 。请你从 nums 中找出并返回总和为 target 的元素组合的个数。
题目数据保证答案符合 32 位整数范围。
def combinationSum4(nums:'List[int]',target:int)->int:dp=[0]*(target+1)dp[0]=1for i in range(1,target+1):for j in rang(len(nums)):if i=nums[j]>0:dp[i]+=dp[i-nums[j]]return dp[target]