编程实现atoi()函数

本文介绍了一种将字符串转换为整数的ATOI函数实现方法,包括处理正负号、去除前导空格及非数字字符等功能,并提供了一个简洁的实现示例。

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

函数描述:

将字符串str转换成一个整数并返回结果。参数str以数字开头,当函数从str中读到非数字字符则结束转换并将结果返回。


int ATOI( const char *str )
{
    if (str == 0 ) return 0;
    char c;
    int nRet = -1;
    for (;;)
    {
        c = *(str++);
        if ( c >= '0' && c <= '9')
        {
            if (nRet==0 || nRet==-1) {nRet = c - '0';}// 正数第一个数字
            else if (nRet==-2) {nRet = -( c - '0');}// 负数第一个数字
            else nRet = nRet * 10 + ( c - '0');// 其他数字
            continue;
        }
        if ( ( (c > 0x08 && c < 0x0E) || c == 0x20) && (nRet==-1)) continue;// 剪掉空白字符
        if ( c == '+' && (nRet==-1) ) { nRet = 0; continue; }// 正数符号
        if ( c == '-' && (nRet==-1) ) { nRet = -2; continue; }// 负数符号
        if ( (nRet == -1) || (nRet == -2) ) nRet = 0;// 失败返回0值
        break;
    }
    return nRet;
}

简单的实现(百度百科):

#include <cctype>
int my_atoi(const char* p){
assert(p != NULL);
bool neg_flag = false;// 符号标记
int res = 0;// 结果
if(p[0] == '+' || p[0] == '-')
neg_flag = (*p++ != '+');
while(isdigit(*p)) res = res*10 + (*p++ - '0');
return neg_flag ?0 -res : res;
}



评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值