把字符串转换成整数

剑指OFFER题39------按牛客网通过率排序

时间:2019.1.2.2151
作者:Waitt

题目

将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0。

输入描述:

输入一个字符串,包括数字字母符号,可以为空

输出描述:

如果是合法的数值表达则返回该数字,否则返回0

实例

输入:
+2147483647
1a33
输出:
2147483647
0

时间限制:1秒 空间限制:32768K 热度指数:144194

解答

此题与判断 《字符串是否为数值》不同,此题要将字符串转换成整数,那么除了首位可以出现正负号,其余均应为数字

特殊情况处理:

  1. 单独的正负号:‘+’、’-’
  2. 输入为空
  3. 超出INT的范围
class Solution {
public:
    int StrToInt(string str) {
        int a=0;//数字位
        int f=0;//符号位,默认为0
        if(str.empty())//输入为空
            return a;
        int n=str.size();
        //首位特殊处理
        if(str[0]=='+')
            f=1;//有正号时,f为1
        else if(str[0]=='-')
            f=-1;//有负号时,f为-1
        else if(str[0]<'0'||str[0]>'9')
            return a;//其它字符
        else
            a=str[0]-'0';//转换数字时必须减‘0’
        if(n==1)
            return a;
        for(int i=1;i<n;i++)
        {
            if(str[i]<'0'||str[i]>'9')
                return 0;
            else
                a=a*10+str[i]-'0';//数字表达转换
        }
        if(f>=0&&a<=INT_MAX)//正数时溢出判断
            return a;
        if(f<0)//负数溢出判断
        {
            a=a*f;//将a转换为负数再进行判断
            if(a>=INT_MIN)
                return a;
        }
        return 0;
    }
};

CHAR转INT时,每一步都需要减’0’,如有漏写,则会出现错误。
最后判断溢出时,可将其转换成对应符号的数再判断,会更加条理清晰。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值