英雄会(csdn pongo)题解之字符串转换成整数

题目详情:

输入一个表示整数的字符串,把该字符串转换成整数并输出,例如输入字符串"345",则输出整数345。

请完成函数StrToInt,实现字符串转换成整数的功能。

友情提醒

提交代码之前,请复查下你的程序,比如当给的字符串是如左边图片所示的时候,有考虑到么?

当然,它们各自对应的正确输出如右边图片所示(假定你是在32位系统下,编译环境是VS2008以上)

------------------------------------------分割线------------------------------------------------------

这道题比较简单,需要注意的是当字符串表示的置超出了int的表示范围(-2147483648~2147483647)的时候,取int的上界\下界值。

C++代码如下:

#include <iostream>
#include <string>
#include <vector>
#include <limits>
#include <tchar.h>
using namespace std;


int StrToInt(const char* str){
    int len=strlen(str);
    bool findFlag=false;
    bool findDig=false;
    long long res=0;//字符串对应的值可能超出int的表示范围,所以这里用long long,最后再转换为int
    int sign=1;
    for(int i=0;i<len;++i){
        if(str[i]<='9'&&str[i]>='0'){
            findDig=true;
            res*=10;
            res+=str[i]-48;
        }else if(str[i]=='-'){
            if(!findFlag&&!findDig){
                findFlag=true;
                sign=-1;
            }else break;
        }else if(str[i]=='+'){
            if(!findFlag&&!findDig){
                findFlag=true;
                sign=1;
            }else break;
        }else if(str[i]==' '){
            if(!findFlag&&!findDig)
                continue;
            else
                break;
        }else {
            break;
        }
    }
    res*=sign;
	//注意字面值常量后面的LL,否则会被认为是int导致溢出
    if(res<=-2147483649LL)
        res=-2147483648;
    else if(res>=2147483648LL)
        res=2147483647;
	//error
    /*if(res==-2147483649){
        std::cout<<"-----"<<res<<std::endl;
        res=-2147483648;
    }else if(res==2147483648)
        res=2147483647;
    */
    return res;
}



//start 提示:自动阅卷起始唯一标识,请勿删除或增加。
int main(){   
    int a=(int)((long long)(-1));
    std::cout<<"a="<<a<<std::endl;
    std::cout<<StrToInt("")<<std::endl;
    std::cout<<StrToInt("1")<<std::endl;
    std::cout<<StrToInt("+1")<<std::endl;
    std::cout<<StrToInt("-1")<<std::endl;
    std::cout<<StrToInt("123")<<std::endl;
    std::cout<<StrToInt("-123")<<std::endl;
    std::cout<<StrToInt("010")<<std::endl;
    std::cout<<StrToInt("+00131204")<<std::endl;
    std::cout<<StrToInt("-01324000")<<std::endl;
    std::cout<<StrToInt("2147483647")<<std::endl;
    std::cout<<StrToInt("-2147483647")<<std::endl;
    std::cout<<StrToInt("-2147483648")<<std::endl;
    std::cout<<StrToInt("2147483648")<<std::endl;
    std::cout<<StrToInt("-2147483649")<<std::endl;
    //std::cout<<std::endl;
    std::cout<<StrToInt("abc")<<std::endl;
    std::cout<<StrToInt("-abc")<<std::endl;
    std::cout<<StrToInt("1a")<<std::endl;
    std::cout<<StrToInt("23a8f")<<std::endl;
    std::cout<<StrToInt("-3924x8fc")<<std::endl;
    std::cout<<StrToInt("   321")<<std::endl;
    std::cout<<StrToInt("   -321")<<std::endl;
    std::cout<<StrToInt("123  456")<<std::endl;
    std::cout<<StrToInt("123   ")<<std::endl;
    std::cout<<StrToInt("   - 321")<<std::endl;
    std::cout<<StrToInt("   +4488")<<std::endl;
    std::cout<<StrToInt("  +  413")<<std::endl;
    std::cout<<StrToInt(" ++c")<<std::endl;
    std::cout<<StrToInt(" ++1")<<std::endl;
    std::cout<<StrToInt(" --2")<<std::endl;
    std::cout<<StrToInt("  -2")<<std::endl;
} 
//end //提示:自动阅卷结束唯一标识,请勿删除或增加。

时间复杂度是:O(length)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值