把字符串转换成整数

题目描述

将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0

输入描述:

输入一个字符串,包括数字字母符号,可以为空

输出描述:

如果是合法的数值表达则返回该数字,否则返回0

示例1

输入

+2147483647
    1a33

输出

2147483647
    0

思路:

主要考虑一下几点:判断是否溢出;有无正负号;正负号;错误输出;

 class Solution {
public:
    int StrToInt(string str) {
        int n = str.size(), s = 1;
        long long res = 0;
        if(!n) return 0;
        if(str[0] == '-') s = -1;  //判断符号位是否是'-'
        //判断第一位是否为符号,为符号则从第二位开始计数
        for(int i = (str[0] == '-' || str[0] == '+') ? 1 : 0; i < n; ++i){
            if(!('0' <= str[i] && str[i] <= '9')) return 0;
            res = res*10 + str[i] - '0';//最后结果减去0的ASCLL码值
        }  
        return res * s; //结果乘上符号位
    }
};

点赞