java 中int 范围越界校验算法

本文介绍了一种在LeetCode上常见的字符串转整型算法中使用的溢出检查算法。该算法在进行高位乘10并加低位操作前,会先判断运算结果是否会超出int类型的范围,有效避免了程序运行时的溢出错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

LeetCode上老有String 或者 char[]转int的算法,在计算之前需要分析计算是否会超过int 的范围,自己写了一个算法mark 一下。该算法用于       高位乘10 并加低位        操作之前。算法如下:

 

 

/**
 * int 是否越界检验算法
 *
 * @param number        需要校验的数字
 * @param valueOfCharAt 需要校验的最低位
 * @param flag          正负标志
 * @return
 */

private int verification(int number, int valueOfCharAt, int flag) {
    long shangjie = (long) Math.pow(2, 31) - 1;     // 上限
    long xiajie = -(long) Math.pow(2, 31);          // 下限
    int result = 0;
    if (flag == -1) {                               // 负数校验
        if (((-number) < xiajie / 10) || (-number == (xiajie / 10) && valueOfCharAt > 8)) {
            result = 1;
        }
    } else {                                        // 正数校验
        if ((number > shangjie / 10) || ((number == shangjie / 10) && valueOfCharAt > 7)) {
            result = 1;
        }
    }
    return result;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值