8. 字符串转换整数 (atoi)

请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数(类似 C/C++ 中的 atoi 函数)。

函数 myAtoi(string s) 的算法如下:

读入字符串并丢弃无用的前导空格
检查下一个字符(假设还未到字符末尾)为正还是负号,读取该字符(如果有)。 确定最终结果是负数还是正数。 如果两者都不存在,则假定结果为正。
读入下一个字符,直到到达下一个非数字字符或到达输入的结尾。字符串的其余部分将被忽略。
将前面步骤读入的这些数字转换为整数(即,"123" -> 123, "0032" -> 32)。如果没有读入数字,则整数为 0 。必要时更改符号(从步骤 2 开始)。
如果整数数超过 32 位有符号整数范围 [−231, 231 − 1] ,需要截断这个整数,使其保持在这个范围内。具体来说,小于 −231 的整数应该被固定为 −231 ,大于 231 − 1 的整数应该被固定为 231 − 1 。
返回整数作为最终结果。
注意:

本题中的空白字符只包括空格字符 ' ' 。
除前导空格或数字后的其余字符串外,请勿忽略 任何其他字符。
> 标准解法


class Solution {
public:
    int myAtoi(string s) {
        int i = 0, sign = 1, tmp = 0;        //没有符号字符时sign是正数

        while(s[i] == ' ')  ++i;              //1.忽略前导空格

        if(s[i] == '+' || s[i] == '-')        //2.确定正负号
            sign = (s[i++] == '-') ? -1 : 1;  //s[i]为+的话sign依旧为1,为-的话sign为-1

        while(s[i] >= '0' && s[i] <= '9')     //3.检查输入是否合法
        {
            if(tmp > INT_MAX / 10 || (tmp == INT_MAX / 10 && s[i] - '0' > 7)) //4.是否溢出
                return sign == 1 ? INT_MAX : INT_MIN;
            tmp = tmp * 10 + (s[i++] - '0');  //5.不加括号有溢出风险
        }
        return tmp * sign;
    }
};

> 我的解法


class Solution {
public:
    int myAtoi(string s) {
        int flag = 0;
        int num = 0;
        int len = s.size();
        int i = 0;
        vector<int> nums;
        nums.clear();
        for (; i < len; i++) {
            if (s[i] == ' ') continue;
            else if (s[i] == '.') return 0;
            else if (s[i] >= 'a' && s[i] <= 'z') {
                return 0;
            }
            else if (s[i] >= 'A' && s[i] <= 'Z') {
                return 0;
            }
            else if (s[i] == '+') {
                flag = 1;
                i++;
                break;
            }
            else if (s[i] == '-') {
                flag = -1;
                i++;
                break;
            }
            else {
                flag = 1;
                break;
            }
        }
        //处理前部字符0
        for (; i < len; i++) {
            if (s[i] == '0') {
                continue;
            }
            else {
                break;
            }
        }
        //处理数字
        for (; i < len; i++) {
            if (s[i] <= '9' && s[i] >= '0') {
                num = s[i] - '0';
                nums.emplace_back(num);
            }
            else {
                break;
            }
        }
        long long res = 0;
        len = nums.size();
        if(len > 10) return flag>0?(pow(2,31)-1):-pow(2,31);
        for (const auto& j : nums) {
            res += flag * j * pow(10, len - 1);
            if(res < -pow(2,31)) return -pow(2,31);
            if(res > (pow(2,31)-1)) return (pow(2,31)-1);
            len--;
        }
        return res;
    }
};
posted @   xiazichengxi  阅读(12)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示
主题色彩