LeetCode String to Integer (atoi)

atoi (表示 ascii to integer)是把字符串转换成整型数的一个函数,atoi( ) 函数会扫描参数 nptr字符串,跳过前面的空白字符(例如空格,tab缩进等,可以通过isspace( )函数来检测),直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回

以上是百度百科对atoi的定义,因此在做这个题的时候需要考虑各方面的因素,包括sum的溢出、忽略输入字母前的空格、判断正负、以及遇到非数字字符串时停止,写的稍微有点啰嗦。


class Solution {
public:
    int myAtoi(string str);
};

int Solution::myAtoi(string str)
{
    const int max = 0x7fffffff;
    const int min = 0x80000000;
    int flag = 1;
    int single = 0;
    long long sum = 0;
    int i =0;
    
    if(str.empty())
        return 0;
    
    while(str[i]!='\0'&& str[i]==' ')
        ++i;
    
    if(str[i]=='\0')
        return 0;
        
    if(str[i] == '+' || str[i] == '-')
    {
        str[i] == '+' ? flag = 1 : flag = -1;
        ++i;
    }
    
    while(str[i] == '0')
    {
        ++i;
    }
    
    while(str[i] != '\0')
    {
        if(str[i]>='0' && str[i]<='9')
        {
            sum = sum*10 +flag*(str[i] - '0');
            single = 1;
        }
        else
        {
            if(single == 1)
            {
                if(sum>max || sum<min)
                     return sum>0 ? max : min;
                else return sum;
            }
            else
            {
                return 0;
            }
        }
        
        if(sum>max || sum<min)
        {
            return sum>0 ? max : min;
        }
        ++i;
    }
    return sum;
  
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值