189 8069 5689

字符串转化为整数(模拟实现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 '9')
            {
                sum = 0;
                break;
            }
            sum = sum * 10 + str[i] - '0';
        }
        return symbol * sum;
    }
};

网页标题:字符串转化为整数(模拟实现atui)
本文地址:http://jkwzsj.com/article/jhhhhe.html

其他资讯