剑指Offer-67:把字符串转换成整数

本文解析了一道关于如何不使用库函数将字符串转换为整数的问题,并提供了详细的代码实现及边界条件处理方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:

将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0

链接:

剑指Offer(第2版):P318

思路标签:

  • 边界条件

解答:

  • 该题目主要考察的就是边界条件:数据上下溢出、空字符串、只有正负号、有无正负号、错误标志输出
class Solution {
public:
    enum Status { kValid = 0, kInvalid };
    int g_nStatus = kValid;

    int StrToInt(string str) {
        g_nStatus = kInvalid;
        long long num = 0;
        const char* cstr = str.c_str();
        if ((cstr != nullptr) && (*cstr != '\0'))
        {
            int minus = 1;
            if (*cstr == '-')
            {
                minus = -1;
                cstr++;
            }
            else if (*cstr == '+')
                cstr++;

            while (*cstr != '\0')
            {
                if (*cstr > '0' && *cstr < '9')
                {
                    g_nStatus = kValid;
                    num = num * 10 + (*cstr - '0');
                    cstr++;
                    if (((minus>0) && (num > 0x7FFFFFFF)) ||
                        ((minus<0) && (num > 0x80000000)))
                    {
                        g_nStatus = kInvalid;
                        num = 0;
                        break;
                    }
                }
                else
                {
                    g_nStatus = kInvalid;
                    num = 0;
                    break;
                }
            }

            if (g_nStatus == kValid)
                num = num * minus;

        }
        return (int)num;
    }
};

c++相关

string:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值