leetcode-零钱兑换—int溢出
做题的时候一直遇到一个问题,Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: -2147483648
说明Int溢出了。得到的结果一直是- 2147483647。 因为i+coins[j]=1+2147483647 >=Integer.MAX_VALUE;
解决办法是如果溢出了,if(i+coins[j]<0) break;
这里便发现了如果溢出,那么一定是用负数表示的。
x = 2147483647
x+1 = -2147483648
x+2 = -2147483647
当最大值加上 1 时,结果反而变成表示范围中最小的值;当最大值加上 2 时,结
果变成表示范围中次小的值,这就是数据类型的溢出。
算法思路:利用动态规划的思想,在1-amount之间建立一个下标索引,nums表示钱数所需要的最少硬币数量。
首先对已有硬币进行标记,下标都为1。同时注意:当硬币的面值大于amount时,将不会被标记。
开始从1遍历至amount。
如果当前遍历的面值不能用硬币凑出,那么就跳出,说明无法取到这个面值。比如{2,5,10} 永远无法取到1,3,7,9。这些都是不需要判断的。
遍历的面值再加上硬币的面值,nums[i+coins[j]]表示当前面值所需最小硬币数量。
需要添加如下几个判断条件:
1.遍历的钱数i+coins[j]一定要小于amount。
2.当前所需硬币数比原来需要的硬币数量更少,那么更新nums数组。
class Solution {
public int coinChange(int[] coins, int amount) {
if(amount==0)return 0;
long[] nums=new long[amount+1];
for(int i=0;i<coins.length;i++){
if(coins[i]<=amount)nums[coins[i]]=1;
}
for(int i=1;i<=amount;i++){
if(nums[i]==0)continue;
for(int j=0;j<coins.length;j++){
int temp=i+coins[j];
if(temp<0) break; //这里在验证{1,2147483647} 反复出现了错误,因为i+coins[j]已经溢出,溢出是用-22147483647表示,溢出则跳出循环
if(temp<=amount&&(nums[temp]==0||1+nums[i]<nums[temp]))nums[temp]=1+nums[i];
}
}
if(nums[amount]==0)return -1;//这里如果凑不出amount的面值,那么就不需要判断了。
return nums[amount];
}
}
leetcode-零钱兑换—int溢出的更多相关文章
- LeetCode:零钱兑换【322】【DP】
LeetCode:零钱兑换[322][DP] 题目描述 给定不同面额的硬币 coins 和一个总金额 amount.编写一个函数来计算可以凑成总金额所需的最少的硬币个数.如果没有任何一种硬币组合能组成 ...
- Leetcode 518.零钱兑换II
零钱兑换II 给定不同面额的硬币和一个总金额.写出函数来计算可以凑成总金额的硬币组合数.假设每一种面额的硬币有无限个. 注意: 你可以假设 0 <= amount (总金额) <= 500 ...
- Leetcode 322.零钱兑换
零钱兑换 给定不同面额的硬币 coins 和一个总金额 amount.编写一个函数来计算可以凑成总金额所需的最少的硬币个数.如果没有任何一种硬币组合能组成总金额,返回 -1. 示例 1: 输入: co ...
- Java实现 LeetCode 518 零钱兑换 II
518. 零钱兑换 II 给定不同面额的硬币和一个总金额.写出函数来计算可以凑成总金额的硬币组合数.假设每一种面额的硬币有无限个. 示例 1: 输入: amount = 5, coins = [1, ...
- Java实现 LeetCode 322 零钱兑换
322. 零钱兑换 给定不同面额的硬币 coins 和一个总金额 amount.编写一个函数来计算可以凑成总金额所需的最少的硬币个数.如果没有任何一种硬币组合能组成总金额,返回 -1. 示例 1: 输 ...
- 刷题-力扣-518. 零钱兑换 II
518. 零钱兑换 II 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/coin-change-2/ 著作权归领扣网络所有.商业转载 ...
- LC-322. 零钱兑换
322. 零钱兑换 给你一个整数数组 coins ,表示不同面额的硬币:以及一个整数 amount ,表示总金额. 计算并返回可以凑成总金额所需的 最少的硬币个数 .如果没有任何一种硬币组合能组成总金 ...
- SQL语句中 int 溢出 + Asp语句中 Long 溢出
晚上5点多,同事在QQ告诉我,一个用户向他反应,在他登录的时候显示错误信息,我们在管理平台查看该用户的基本信息时,也显示错误信息. 经过初步分析,原来是在执行 SQL语句的时候发生Int溢出: sql ...
- leetcode 322零钱兑换
You are given coins of different denominations and a total amount of money amount. Write a function ...
随机推荐
- AutoComplete的使用方法
百度 酷狗,反正使用搜索功能时,都会看到类似于图一这种自动补全的功能,灰常的方便,今天做一个项目,刚好要加这个功能,于是一通百度之后,总算做出来,源代码在文章末尾会提供下载.还有,我这个是参考了网上的 ...
- 【2017001】IList转DataTable、DataTable转IList
IList转DataTable.DataTable转IList using System; using System.Collections.Generic; using System.Compone ...
- Swift_下标
Swift_下标 点击查看源码 func testSubscripts() { //下标关键字subscript //array测试 struct TestArray { //内部数组 var arr ...
- 常用Sql server 自定义函数
/****** 对象: UserDefinedFunction [dbo].[fun_get_LowerFirst] 脚本日期: 08/04/2012 13:03:56 ******/ IF EXIS ...
- const、let、var的主要区别
接触ES6之后,以前定义变量的方式由var增加了let.const,平时看别人用也不知道如何区别具体差别,好好科普了一下记录下来,方便大家一起学习. var(大家最熟悉的定义方式) 1.可定义全局作用 ...
- jQuery UI.Layout 参数
applyDefaultStyles: true,//应用默认样式 scrollToBookmarkOnLoad:false,//页加载时滚动到标签 showOverflowOnHover:false ...
- 一台ECS服务器,部署多(两)应用,且应用配置不同域名
场景 产品环境服务器有两台,前后端各分配一台服务器.现在在不增加机器的情况下,需要增加部署一套服务给台北地区服务. 现有的前端部署方案. 产品环境部署方案详解 实现 配置NAT步骤 ECS配置多网卡, ...
- 企业网站被黑 dedecms漏洞修复办法
前段时间网站被黑了,从百度打开网站直接被劫持跳转到了彩票,du博网站上去,网站的首页index.html文件也被篡改成一些什么北京sai车,pk10,一些cai票的关键词内容,搞得网站根本无法正常浏览 ...
- go学习笔记-反射(Reflection)
反射(Reflection) 反射是利用reflect包实现的 反射可大大提高程序的灵活性,使得interface{}有更大的发挥余地 反射使用TypeOf和ValueOf函数从接口中获取目标对象信息 ...
- 钓鱼 洛谷p1717
题目描述 话说发源于小朋友精心设计的游戏被电脑组的童鞋们藐杀之后非常不爽,为了表示安慰和鼓励,VIP999决定请他吃一次“年年大丰收”,为了表示诚意,他还决定亲自去钓鱼,但是,因为还要准备2013NO ...