零钱兑换
作者:互联网
零钱兑换一:求兑换最少硬币数
https://leetcode.cn/problems/coin-change/
func coinChange(coins []int, amount int) int { dp:=make([]int,amount+1) //dp[i]标识金额为i的时候,需要的最少硬币数 //初始化 mx:= 99999999999 for i:=0;i<amount+1;i++{ dp[i]=mx } dp[0]=0 //金额为0的时候需要0个硬币 for i:=0;i<len(coins);i++{ for j:=coins[i];j<=amount;j++{ if dp[j-coins[i]]!=mx{ dp[j]=getMin(dp[j],dp[j-coins[i]]+1) //当前这个硬币拿或者不拿,那种情况总硬币数更少 } } } if dp[amount]==mx{ return -1 } return dp[amount] } func getMin(a,b int) int{ if a>b{ return b }else{ return a } }
零钱兑换二:求兑换组合数
https://leetcode.cn/problems/coin-change-2/
func change(amount int, coins []int) int { dp:=make([]int,amount+1) //dp[i]标识兑换总数为i的金额,方案有dp[i]种 dp[0]=1 //金额为0的时候只有一种情况,就是什么都不放 for i:=0;i<len(coins);i++{ for j:=coins[i];j<=amount;j++{ dp[j]=dp[j]+dp[j-coins[i]] } } return dp[amount] }
标签:int,零钱,amount,兑换,dp,change 来源: https://www.cnblogs.com/-citywall123/p/16415971.html