字符串转化为整数(模拟实现atui)

class Solution
{
public:
    int StrToInt(string str)
    {
        if (str.empty())
            return 0;
        int symbol = 1;//自定义正负转换变量
        if (str[0] == '-') //处理负号  
        {
            symbol = -1;
            str[0] = '0'; //这里是字符'0',不是0     
        }
        else if (str[0] == '+') //处理正号      
        {
            symbol = 1;
            //为什么这两步要将str[0]赋值为‘0’?
            //因为如果有正负号输入进来将symbol设置后就可以在后面确定返回值的正负号了
            //然后str[0]给成字符‘0’就是统一sum的计算过程,这一位给成0不会影响计算的结果
            str[0] = '0';
        }           
        int sum = 0;
        for (int i = 0; i<str.size(); ++i)
        {
            if (str[i] < '0' || str[i] > '9')
            {
                sum = 0;
                break;
            }
            sum = sum * 10 + str[i] - '0';
        }
        return symbol * sum;
    }
};
    原文作者:be_better_
    原文地址: https://blog.51cto.com/14239789/2450951
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞