剑指offer系列——49.把字符串转换成整数

Posted xym4869

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指offer系列——49.把字符串转换成整数相关的知识,希望对你有一定的参考价值。

Q:将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0。
输入一个字符串,包括数字字母符号,可以为空。如果是合法的数值表达则返回该数字,否则返回0
示例1
输入
+2147483647
1a33
输出
2147483647
0

T:
注意一个上下溢出的问题。INT_MAX=2147483647,INT_MIN=-2147483649,最大值的绝对值小于最小值的绝对值。
代码:

    int StrToInt(string str) {
        if (str.empty())
            return 0;
        int result = 0;
        int symbol = 1;
        bool flag = false;
        if (str[0] == '+')
            flag = true;
        else if (str[0] == '-') {
            flag = true;
            symbol *= -1;
        }
        int i = 0;
        if (flag)
            i = 1;
        int temp = 0;
        for (; i < str.size(); i++) {
            if (str[i] >= '0' && str[i] <= '9') {
                temp = str[i] - '0';
                if (symbol > 0 && (result >= INT_MAX / 10) && (temp > INT_MAX % 10))
                    return 0;
                if (symbol < 0 && (result * symbol <= INT_MIN / 10) && (temp * symbol < INT_MIN % 10))
                    return 0;
                result = result * 10 + temp;
            } else
                return 0;
        }
        result = result * symbol;
        return result;
    }

以上是关于剑指offer系列——49.把字符串转换成整数的主要内容,如果未能解决你的问题,请参考以下文章

[剑指offer] 49. 把字符串转换成整数

剑指offer 49.综合 把字符串转换成整数

剑指 Offer JZ49 把字符串转换成整数

剑指offer系列39:把字符串转换成整数

剑指Offer对答如流系列 - 把字符串转换成整数

剑指offer(三十二)之把字符串转换成整数