零钱兑换
给定不同面额的硬币 coins 和一个总金额 amount。编写一个函数来计算可以凑成总金额所需的最少的硬币个数。如果没有任何一种硬币组合能组成总金额,返回 -1。
示例 1:
输入: coins = [1, 2, 5], amount = 11输出: 3
解释: 11 = 5 + 5 + 1
示例 2:
输入: coins = [2], amount = 3输出: -1
说明:
你可以认为每种硬币的数量是无限的。
问题:输入{1,2147483647};

做题的时候一直遇到一个问题,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溢出的更多相关文章

  1. LeetCode:零钱兑换【322】【DP】

    LeetCode:零钱兑换[322][DP] 题目描述 给定不同面额的硬币 coins 和一个总金额 amount.编写一个函数来计算可以凑成总金额所需的最少的硬币个数.如果没有任何一种硬币组合能组成 ...

  2. Leetcode 518.零钱兑换II

    零钱兑换II 给定不同面额的硬币和一个总金额.写出函数来计算可以凑成总金额的硬币组合数.假设每一种面额的硬币有无限个. 注意: 你可以假设 0 <= amount (总金额) <= 500 ...

  3. Leetcode 322.零钱兑换

    零钱兑换 给定不同面额的硬币 coins 和一个总金额 amount.编写一个函数来计算可以凑成总金额所需的最少的硬币个数.如果没有任何一种硬币组合能组成总金额,返回 -1. 示例 1: 输入: co ...

  4. Java实现 LeetCode 518 零钱兑换 II

    518. 零钱兑换 II 给定不同面额的硬币和一个总金额.写出函数来计算可以凑成总金额的硬币组合数.假设每一种面额的硬币有无限个. 示例 1: 输入: amount = 5, coins = [1, ...

  5. Java实现 LeetCode 322 零钱兑换

    322. 零钱兑换 给定不同面额的硬币 coins 和一个总金额 amount.编写一个函数来计算可以凑成总金额所需的最少的硬币个数.如果没有任何一种硬币组合能组成总金额,返回 -1. 示例 1: 输 ...

  6. 刷题-力扣-518. 零钱兑换 II

    518. 零钱兑换 II 题目链接 来源:力扣(LeetCode) 链接:https://leetcode-cn.com/problems/coin-change-2/ 著作权归领扣网络所有.商业转载 ...

  7. LC-322. 零钱兑换

    322. 零钱兑换 给你一个整数数组 coins ,表示不同面额的硬币:以及一个整数 amount ,表示总金额. 计算并返回可以凑成总金额所需的 最少的硬币个数 .如果没有任何一种硬币组合能组成总金 ...

  8. SQL语句中 int 溢出 + Asp语句中 Long 溢出

    晚上5点多,同事在QQ告诉我,一个用户向他反应,在他登录的时候显示错误信息,我们在管理平台查看该用户的基本信息时,也显示错误信息. 经过初步分析,原来是在执行 SQL语句的时候发生Int溢出: sql ...

  9. leetcode 322零钱兑换

    You are given coins of different denominations and a total amount of money amount. Write a function ...

随机推荐

  1. platform平台总线

    一.何为平台总线 (1)相对于usb.pci.i2c等物理总线来说,platform总线是虚拟的.抽象出来的.(2)CPU与外部通信的2种方式:地址总线式连接和专用协议类接口式连接.平台总线,是扩展到 ...

  2. HP-UNIX平台修改Oracle processes参数报错:ORA-27154、ORA-27300、ORA-27301、ORA-27302

    OS 版本     :HP-UX B.11.31Oracle版本:11.2.0.4 (RAC) (一)问题描述 最近发现无法连接上数据库,报错信息为“ORA-00020:maximum number ...

  3. 03 Oracle分区表

    Oracle分区表   先说句题外话…   欢迎成都天府软件园的小伙伴来面基交流经验~ 一:什么是分区(Partition)? 分区是将一个表或索引物理地分解为多个更小.更可管理的部分. 分区对应用透 ...

  4. mysql数据库迁移到oracle数据库后 如何删除相同的数据

    mysql数据库迁移到oracle数据库后 如何删除相同的数据 首先搞清楚有多少数据是重复的 select pid from product group by pid having count(pid ...

  5. 学习笔记(1)centos7 下安装nginx

    学习笔记(1)centos7 下安装nginx 这里我是通过来自nginx.org的nginx软件包进行安装的. 1.首先为centos设置添加nginx的yum存储库 1.通过vi命令创建一个rep ...

  6. Vue中异步组件(结合webpack,转载)

    转载,原文出处:https://www.jianshu.com/p/40a364b5e964 1.什么是异步组件? 异步组件就是定义的时候什么都不做,只在组件需要渲染(组件第一次显示)的时候进行加载渲 ...

  7. 纯js轮播图练习-1

    偶尔练习,看视频自己学着做个简单的纯JS轮播. 简单的纯js轮播图练习-1. 样子就是上面图片那样,先不管好不好看,主要是学会运用和理解轮播的原理 掌握核心的理论知识和技术的操作,其他的都可以在这个基 ...

  8. [转]去掉IOS下的input 和textarea的内阴影

    在IOS下,input 和textarea表单默认会有个内阴影,一定程度上影响视觉一致,可通过设置下面代码去掉: input{-webkit-appearance: none;}

  9. Python学习 :json、pickle&shelve 模块

    数据交换格式 json 模块 json (JavaScript Object Notation)是一种轻量级的数据交换语言,以文字为基础,且易于让人阅读.尽管 json 是JavaScript的一个子 ...

  10. STM32_2 简单分析startup函数

    ;******************** (C) COPYRIGHT STMicroelectronics ******************** ;* File Name : startup_s ...