码迷,mamicode.com
首页 > 其他好文 > 详细

String to Integer (atoi)

时间:2014-08-02 12:36:23      阅读:301      评论:0      收藏:0      [点我收藏+]

标签:blog   io   for   问题   ar   div   amp   log   

问题:将字符窜转换成数字
分析:感觉题目不难,但是细节很多,容易想不到
1.数字前面有空格 如s=“    123456”
2.数字前出现了不必要或多于的字符导致数字认证错误,输出0   如s=“   b1234”  ,s=“  ++1233” , s=“ +-1121”
3.数字中出现了不必要的字符,返回字符前的数字 如s=“   12a12” , s=“ 123  123”
4.数字越界 超过了范围(-2147483648--2147483647) 若超过了负数的 输出-2147483648  超过了正数的输出2147483647
在科普一个知识点,倘若某个数超过了2147483647则会变为负数,反过来一样

 

class Solution {
public:
    int atoi(const char *str) {
    long long cur=0;//初始化老是忘记
    int num=0,i=0;
    int flag1=0,flag2=0;
    while(str[i]!=‘\0‘ && str[i]==‘ ‘) i++;//开头空格舍弃
    if(str[i]==‘-‘) flag1++,i++;
    else if(str[i]==‘+‘) flag2++,i++;
    for(; str[i]!=‘\0‘; i++)
    {
        if(str[i]>=‘0‘ && str[i]<=‘9‘)
        {
            if(flag1==2)
            {
                cur=cur*10-(str[i]-‘0‘);//这里是减法,因为cur符号是负号了
                if(cur<-2147483648) return -2147483648;
            }
            else if(flag1==1) cur=-str[i]+‘0‘,flag1++;//将负数的符号记录到cur里
            else
            {
                cur=cur*10+(str[i]-‘0‘);
                if(cur>2147483647) return 2147483647;
            }
        }
        else break;
    }
    num=(int)cur;
    return num;
    }
};

  

String to Integer (atoi),布布扣,bubuko.com

String to Integer (atoi)

标签:blog   io   for   问题   ar   div   amp   log   

原文地址:http://www.cnblogs.com/zsboy/p/3886677.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!