AcWing
  • 首页
  • 活动
  • 题库
  • 竞赛
  • 校园
  • 应用
  • 文章
    • 题解
    • 分享
    • 问答
  • 吐槽
  • 登录/注册

AcWing 87. 把字符串转换成整数    原题链接    中等

作者: 作者的头像   nonstop ,  2022-06-24 15:12:26 ,  所有人可见 ,  阅读 10


0


题目描述

blablabla

样例

blablabla

算法1

(暴力枚举) $O(n^2)$

blablabla

时间复杂度

参考文献

C++ 代码

class Solution {
public:
    int strToInt(string str) {
        string s2="";
        int len=0;
        bool tag=true;
        int a=0,result;
        for(int i=0;i<str.length();i++){
            if(str[i]!=' '&&str[i]=='-'){tag=false;a=i+1;break;}
            else if(str[i]=='+'){a=i+1;break;}
        }
        //if(a!=0)a+=1;
        for(int i=a;i<str.length();i++){
            if(str[i]>='0'&&str[i]<='9'){
                s2+=str[i];len++;
            }
            else break;
            /*
            if(str[i]>='0'&&str[i]<='9'&&(i+1==str.length()||(str[i+1]<'0'||str[i+1]>'9'))){
                if(len>s2.length()){
                    s2=s1;len=0;
                }
                else;
            }
            */
        }
        if(s2.length()==0)return 0;
        else if(s2.length()>=10){
            if(s2.length()>10)
                if(tag == false) return -2147483648;
                else return 2147483647;
            else{
                if(214748364<conINT(s2.substr(0,9))){
                     if(tag == false) return -2147483648;
                     else return 2147483647;
                }
                else if(214748364>=conINT(s2.substr(0,9))){
                    if(s2[9]<'8'){
                        if(tag == false) return -conINT(s2);
                        else return conINT(s2);
                    }
                    else if(s2[9]=='8'){
                        if(tag==false) return -2147483648;
                        else return 2147483647;
                    }
                    else{
                        if(tag == false) return -2147483648;
                        else return 2147483647;
                    }
                }
            }

        }
        else {
            if(tag == false) return -conINT(s2);
            else return conINT(s2);
        }

    }
    int conINT(string str){
        int result=0;
        for(int i=0;i<str.length();i++){
            result=result*10+((int)str[i]-48);
        }
        return result;
    }

};

算法2

(暴力枚举) $O(n^2)$

blablabla

时间复杂度

参考文献

C++ 代码

blablabla

0 评论

你确定删除吗?
1024
x

© 2018-2022 AcWing 版权所有  |  京ICP备17053197号-1
用户协议  |  常见问题  |  联系我们
AcWing
请输入登录信息
更多登录方式: 微信图标 qq图标
请输入绑定的邮箱地址
请输入注册信息