coin_change

  • 2022-12-14
  • 浏览 (357)

coin_change.go 源码

package main

import "math"

//零钱兑换

func coinChange(coins []int, amount int) int {
	dp := make([]int, amount+1)
	for i := range dp {
		dp[i] = amount + 1
	}
	dp[0] = 0

	for i := 1; i <= amount; i++ {
		for _, c := range coins {
			if i >= c {
				dp[i] = int(math.Min(float64(dp[i]), float64(dp[i-c]+1)))
			}
		}
	}

	if dp[amount] > amount {
		return -1
	}
	return dp[amount]
}

你可能感兴趣的文章

decode_ways

delete_operation_two_strings

edit_distance

0  赞