把字符串转换成整数 ----《剑指offer》面试题49

题目

实现C语言的库函数atoi。

思路

实现简单,但是要考虑各种输入情况,以及返回的情况。

(1) 输入的字符串是无效的字符串或者空串;
(2) 输入的字符串带有正负符号;
(3) 正负符号之后,没有紧接数字;
(4) 输入的字符串中,有其它非数字字符;
(5) 转换成int类型时,字符串的值会溢出(上溢与下溢);
(6) 数字的结尾不是正常结尾;
(7) 正确区分返回值为0 与 非正常返回值;

代码

#include <iostream>

using namespace std;

enum Status
{
    kValid = 0,
    kInvalid
};

int g_nStatus = kValid; //  输入是否有效

long long StrToIntCore(const char* digit, bool minus)
{
    long long num = 0;

    while (*digit != '\0')
    {
        //  判断是否为数字
        if (*digit >= '0' && *digit <= '9')
        {
            int flag = minus ? -1 : 1;
            num = num * 10 + flag * (*digit - '0');

            //  判断数字是否溢出  -0x80000000 <= int <= 0x7fffffff
            if ( (!minus && num > 0x7fffffff) || (minus && num < signed(0x80000000) ) )
            {
                num = 0;
                break;
            }

            digit++;
        }
        else
        {
            num = 0;
            break;
        }
    }

    //  判断数字结尾是否合法
    if (*digit == '\0')
        g_nStatus = kValid;

    return num;
}


//  将字符串转换成 int型 数字
int StrToInt(const char* str)
{
    g_nStatus = kInvalid;
    long long num = 0;

    //  考虑是否为空字符串
    if (str != nullptr && *str != '\0')
    {
        //  考虑是否有正负符号
        bool minus = false;
        if (*str == '+')
            str++;
        else if (*str == '-')
        {
            str++;
            minus = true;
        }

        //  判断是否以数字开头
        if (*str != '\0')
        {
            num = StrToIntCore(str, minus);
        }
    }

    return int(num);
}


int main()
{
    char str[] = "-1230";
    int num = StrToInt(str);
    g_nStatus == kValid ? cout << "the num is: " << num << endl \
                : cout << "the num is invalid." << endl;
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值