LeetCode: 8. 字符串转整数(atoi)

题目

实现 atoi,将字符串转为整数。

提示: 仔细考虑所有输入情况。如果你想挑战自己,请不要看下面并自己考虑所有可能的输入情况。

说明: 这题解释的比较模糊(即没有指定输入格式)。你得事先汇集所有的输入情况。

atoi的要求:

这个函数需要丢弃之前的空白字符,直到找到第一个非空白字符。之后从这个字符开始,选取一个可选的正号或负号后面跟随尽可能多的数字,并将其解释为数字的值。

字符串可以在形成整数的字符后包括多余的字符,将这些字符忽略,这些字符对于函数的行为没有影响。

如果字符串中的第一个非空白的字符不是有效的整数,或者没有这样的序列存在,字符串为空或者只包含空白字符则不进行转换。

如果不能执行有效的转换,则返回0。如果正确的值超过的可表示的范围,则返回INT_MAX(2147483647)或INT_MIN(-2147483648)。

分析

  • 题目要求第一个非空字符开始算必须是个整数
  • 注意使用 long 来判定整数是否越界
  • 不要使用 Math.pow(2, 31) 因为返回的 doble 类型数据转化为 int 后失真

解题

class Solution {
    public int myAtoi(String str) {
        str = str.trim();
        if (str.length() == 0 || str.charAt(0) != '+' && str.charAt(0) != '-' && !isNum(str.charAt(0))) {
            return 0;
        }
        int flag = 1;
        long data = 0;
        // Init the loop param.
        int i = 0;
        int len = str.length();

        // Positive or negative num.
        if (str.charAt(i) == '+' || str.charAt(i) == '-') {
            flag = str.charAt(i) == '+' ? 1 : -1;
            i++;
        }
        // Find the data.
        while(i<len && isNum(str.charAt(i))) {
            data = data*10 + (str.charAt(i) - '0');
            if (flag*data < Integer.MIN_VALUE) {
                return Integer.MIN_VALUE;
            }
            if (flag*data > Integer.MAX_VALUE) {
                return Integer.MAX_VALUE;
            }
            i++;
        }
        return flag*(int)data;
    }

    public boolean isNum(char c) {
        if ('0' <= c && c <= '9') {
            return true;
        }
        return false;
    }

}

启示

  • 注意 char 类型的比较,比较字符而不是数字,’0’ 转化为 int 是 47
  • 当 char 与数字进行比较时,可以用 c - ‘0’
  • 注意输入为空或者单个元素时的情况
  • 不要使用 Math.pow(2, 31) 因为返回的 doble 类型数据转化为 int 后失真
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值