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

[LeetCode]atoi 边界条件

时间:2014-11-05 10:56:56      阅读:220      评论:0      收藏:0      [点我收藏+]

标签:blog   io   ar   for   sp   on   2014   log   bs   

需要跳过前置的空格和0;

必须考虑前置符号;

int的取值范围为[0x7fffffff, 0x80000000],如果超过了这个边界,则取边界。为了判断是否超过边界,需要用一个更大的整数类型表示,这里用long long;

“       -12a12” 输出的是前面有效部分-12



class Solution {
public:
    int atoi(const char *str) {
        if(!str||*str=='\0')return 0;
        int flag=1;
        long long ans=0;
        while(*str&&(*str==' '||*str=='0'))str++;
        if(str[0]=='+')
            str++;
        else if(str[0]=='-')
            flag=-1,str++;
        for(;*str!='\0';str++){
            if(*str>='0'&&*str<='9')
                ans=ans*10+(*str-'0');
            else
                break;
            if(flag==1&&ans>0x7fffffff){
                ans=0x7fffffff;break;
            }
            else if(flag==-1&&ans>0x80000000){
                ans=0x80000000;break;
            }
        }
        int ians=flag*((int)ans);
        return ians;
    }
};


[LeetCode]atoi 边界条件

标签:blog   io   ar   for   sp   on   2014   log   bs   

原文地址:http://blog.csdn.net/cklsoft/article/details/40818045

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