判断Int类型数据是否溢出

今天在leetcode上做题时,又遇到了与数据溢出相关的内容,在此记录下吧。
在头文件“limits.h”中有各种基本数据类型的最大最小值。

/* Minimum and maximum values a `signed int' can hold.  */
#  define INT_MIN   (-INT_MAX - 1)
#  define INT_MAX   2147483647

/* Maximum value an `unsigned int' can hold.  (Minimum is 0.)  */
#  define UINT_MAX  4294967295U

/* Minimum and maximum values a `signed long int' can hold.  */
#  if __WORDSIZE == 64
#   define LONG_MAX 9223372036854775807L
#  else
#   define LONG_MAX 2147483647L
#  endif
#  define LONG_MIN  (-LONG_MAX - 1L)

/* Maximum value an `unsigned long int' can hold.  (Minimum is 0.)  */
#  if __WORDSIZE == 64
#   define ULONG_MAX    18446744073709551615UL
#  else
#   define ULONG_MAX    4294967295UL
#  endif

#  ifdef __USE_ISOC99

/* Minimum and maximum values a `signed long long int' can hold.  */
#   define LLONG_MAX    9223372036854775807LL
#   define LLONG_MIN    (-LLONG_MAX - 1LL)

/* Maximum value an `unsigned long long int' can hold.  (Minimum is 0.)  */
#   define ULLONG_MAX   18446744073709551615ULL
#  else
#   define ULONG_MAX    4294967295UL
#  endif

举例,将一个string转换为int。

//64位
#  define INT_MIN   (-INT_MAX - 1)
#  define INT_MAX   2147483647

这是leetcode上的一道题目,将string转换为int。

class Solution {
public:
    int myAtoi(string str) {
        int sum = 0;
        bool flag = true;
        for (int j=0; j<str.size(); ) {
            if (str[j]==' ') {
                str.erase(j, 1);
                j = 0;
            } else {
                break;
            }
        }
        //是否为负数
        bool negative = str[0] == '-' ? true : false;
        int i = str[0] == '-' || str[0] == '+' ? 1 : 0;
        while (isdigit(str[i])) {
            //判断是否溢出
            if (sum > INT_MAX / 10 || (sum == INT_MAX / 10 && str[i] - '0' > 7)) {
                if (negative)
                    return INT_MIN;
                else
                    return INT_MAX;
            }
            sum = sum * 10 + (str[i++] - '0');
        }
        return negative ? -sum : sum;
    }
};

判断的方法是,如果一个int类型的数值的绝对值已经大于“INT_MAX / 10”,或者它等于“INT_MAX / 10”但是其下一个将要相加的数字大于了7(因为IN_MAX=2147483647),那就说明它溢出了。

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值