内容简介:You are given coins of different denominations and a total amount of money amount. Write a function to compute the fewest number of coins that you need to make up that amount. If that amount of money cannot be made up by any combination of the coins, retur
You are given coins of different denominations and a total amount of money amount. Write a function to compute the fewest number of coins that you need to make up that amount. If that amount of money cannot be made up by any combination of the coins, return -1.
Example 1:
Input: coins = [1, 2, 5], amount = 11 Output: 3 Explanation: 11 = 5 + 5 + 1
Example 2:
Input: coins = [2], amount = 3 Output: -1
Note:
You may assume that you have an infinite number of each kind of coin.
难度:medium
题目:给定不同面值的硬币和一总金额。写一个函数来计算你需要的最少的硬币数量来构成这个总金额。如果这笔钱不能用硬币的任何组合来构成,则返回-1。
思路:DP
total[i]表示这个金额最少需要多少硬币组成。
total[amount] = Math.min(total[amount - coins[i]] + 1) (total[amount - coins[i]] > 0)
(total[amount - coins[i]] = 0) 意味着不可达。
Runtime: 13 ms, faster than 97.29% of Java online submissions for Coin Change.
Memory Usage: 38 MB, less than 42.39% of Java online submissions for Coin Change.
class Solution {
public int coinChange(int[] coins, int amount) {
if (null == coins || coins.length < 1 || amount <= 0) {
return 0;
}
int[] total = new int[amount + 1];
Arrays.sort(coins);
for (int i = 0; i < coins.length && coins[i] < total.length; i++) {
total[coins[i]] = 1;
}
for (int i = coins[0]; i <= amount; i++) {
if (total[i] > 0) {
continue;
}
total[i] = amount + 1;
for (int j = 0; j < coins.length && i - coins[j] >= 0; j++) {
if (total[i - coins[j]] > 0) {
total[i] = Math.min(total[i - coins[j]] + 1, total[i]);
}
}
}
return total[amount] > amount || total[amount] <= 0 ? -1 : total[amount];
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
expert one-on-one J2EE Development without EJB 中文版
[美] Rod Johnson、Juergen Hoeller / JavaEye / 电子工业出版社 / 2005-9 / 59.80元
乍一看这本书的名字,Expert one on one J2EE development without EJB并没有给人带来太冲击。毕竟关于J2EE的书太多了,而without EJB看上去有点象是故意挑衅EJB的感觉。一本J2EE的书怎么可能会给人带来信念或思维的冲击呢?但是它做到了,它不仅使自己变成了不朽的经典,也使Rod Johnson成为了我最近一年的新偶像。 ......一起来看看 《expert one-on-one J2EE Development without EJB 中文版》 这本书的介绍吧!
在线进制转换器
各进制数互转换器
图片转BASE64编码
在线图片转Base64编码工具