模拟实现atoi、itoa

atoi
先来罗列一下所有被转换的字符串可能的形式:

"     +5623852365223" // 溢出,无效值,ret=0
"     +5623"          // 正常,ret=5623
"-5592"               // 正常 ret=5592
"+321"                // 正常 ret=321
"/5262-22"            // 无效值 ret=0
"456413      "        // 正常 ret=456413
"fdf"                 // 无效值 ret=0
"4564fgh"             // 无效值 ret=4564
"g4564fgh"            // 无效值 ret=0
"456   456"           // 正常 ret=456456
"45fgh64"             // 无效值 ret=45
"+2147483647"         // 正常 ret=2147483647
//把字符串转换成整数atoi
#include<iostream>
using namespace std;
enum status{ VALID=0,INVALID};
int flag = VALID;//标识是否为有效值

int StrToInt(const char *str)
{
    long long ret = 0;//转换后的值
    int Symbol = 1;//判断符号
    flag = VALID;
    if (str == NULL || *str == '\0')
    {
        flag = INVALID;
        cout << flag << " ";
        return 0;
    }
    //跳过空格
    while (isspace(*str))
        ++str;
    //判断符号
    if (*str == '+')
        str++;
    else if (*str == '-')
    {
        Symbol = -1;
        str++;
    }
    //不合法字符
    else if (*str < '0' || *str > '9')
    {
        flag = INVALID;
        cout << flag << " ";
        return 0;
    }
    //正常情况
    while (*str != '\0' && *str >= '0' && *str <= '9')
    {
        ret = ret * 10 + (*str - '0');
        str++;
        //跳过空格
        while (isspace(*str))
        {
            ++str;
        }   
        if (*str != '\0' && (*str < '0' || *str > '9'))
        {
            flag = INVALID;
            cout << flag << " ";
            return (int)(ret*Symbol);
        }
    }
    ret = ret*Symbol;
    //判断是否溢出
    if (ret > 0x7fffffff && Symbol == 1 || ret < (signed int)0x80000000 && Symbol == -1)
    {
        flag = INVALID;
        cout << flag << " ";
        return 0;
    }
    cout << flag << " ";
    return (int)ret;
}
//测试用例
int main()
{
    cout << StrToInt("     +5623852365223")<<endl;
    cout << StrToInt("-5592") << endl;
    cout << StrToInt("+321") << endl;
    cout << StrToInt("/5262-22") <<endl;
    cout << StrToInt("456413      ") << endl;
    cout << StrToInt("fdf") << endl;
    cout << StrToInt("4564fgh") << endl;
    cout << StrToInt("g4564fgh") <<endl;
    cout << StrToInt("456   456") <<endl;
    cout << StrToInt("45fgh64") << endl;
    cout << StrToInt("+2147483647") << endl;
    system("pause");
    return 0;
}

itoa:

//把整数转换成字符串itoa
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include <stdlib.h>
using namespace std;
void Reverse(char *str)
{
    char *start = str;
    char *end = str;
    while (*end != '\0')
        ++end;
    --end;
    while (start < end)
    {
        std::swap(*start, *end);
        ++start;
        --end;
    }
}
char *Itoa(int val,char *str,int radix)
{
    char flag=0;
    char tmp[37] = "0123456789abcdefghijklmnopqrstuvwxyz";
    int i = 0;
    unsigned int num;
    if (radix<2 || radix>36)
    {
        cout << "error radix" << endl;
        return str;
    }
    if (radix == 10 && val < 0)//十进制且是负数时需要处理符号
        flag = '-';
    num = unsigned(val);//主要针对负数(将负数转为无符号整型)
    while (num)
    {
        str[i++] = tmp[num%radix];
        num /= radix;
    }
    if (flag == '-')
        str[i++] = '-';
    str[i] = '\0';
    Reverse(str);
    return str;
}
int main()
{
    char str[100] = { 0 };
    cout<<Itoa(10, str, 2)<<endl;
    cout<<_itoa(-10, str, 2)<<endl;
    system("pause");
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值