前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >LeetCode 8 String to Integer (atoi)

LeetCode 8 String to Integer (atoi)

作者头像
ShenduCC
发布2019-06-16 12:02:32
2930
发布2019-06-16 12:02:32
举报
文章被收录于专栏:算法修养

题目

c++

多注意注意

代码语言:javascript
复制
class Solution {
public:
    int myAtoi(string str) {
        
        int len = str.length();
        int tag=0;
        int tag2=0;
        char tag3='x';
        string num="";
        for(int i=0;i<len;i++)
        {
            if(str[i]!=' '&&isNumber(str[i])==0)
            {
                if(tag==0)
                    return 0;
                if(tag==1)
                    break;
            }
            if(str[i]==' ')
            {
                if(tag==0)
                    continue;
                if(tag==1)
                    break;
            }

            if(isNumber(str[i])==1)
            {
                tag=1;
                if(str[i]=='+'||str[i]=='-')
                {
                    if(num==""&&tag3!='x')
                        return 0;
                    if(tag2==1&&num!="")
                        break;
                    tag3 = str[i];
                }
                if(str[i]>='0'&&str[i]<='9')
                {
                    tag2 = 1;
                    num+=str[i];
                }
            }
        }
        long long int z = (long long int) pow(2,31)-1;
        long long int y = (z+1)*-1;
        long long int ans=0;
        int pos=0;
        for(int i=0;i<num.length();i++)
        {
            if(num[i]=='0'&&pos==0)
            {
                continue;
            }
            if(num[i]!='0'&&pos==0)
            {
                pos=1;
                ans=ans*10+(num[i]-'0');
                continue;
            }
            if(pos==1)
            {
                ans=ans*10+(num[i]-'0');
            }
            if(ans >= z)
                break;
            
        }
        
    
        
        if(tag3=='-')
            ans=ans*-1; 
        
        if(ans > z)
        {
            ans = z;   
        }
        if(ans < y)
        {
            ans = y;
        }
        return ans;
        
    }
    
    int isNumber(char s)
    {
        if(s>='0'&&s<='9')
            return 1;
        if(s=='+'||s=='-')
            return 1;
        
        return 0;
    }
};
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-06-15 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档