#include <iostream>
using namespace std;
void swap(char &a, char &b)
{
char c = a;
a = b;
b = c;
}
void reverse(char str[], int n)
{
int start = 0;
int end = n - 1;
while (start < end)
{
swap(str[start++], str[end--]);
}
}
char* myItoa(int n, char *str, int base)
{
int i = 0;
bool isNegative = false;
if (0 == n)
{
str[i++] = '0';
str[i] = '\0';
return str;
}
if (n < 0 && base == 10)
{
isNegative = true;
n = -n;
}
while (n != 0)
{
int rem = n % base;
str[i++] = (rem > 9) ? (rem - 10) + 'a' : rem + '0';
n = n / base;
}
if (isNegative)
{
str[i++] = '-';
}
str[i] = '\0';
reverse(str, i);
return str;
}
int main()
{
char str[100];
cout<<myItoa(1567, str, 10)<<endl;
cout<<myItoa(-222, str, 10)<<endl;
cout<<myItoa(1024, str, 2)<<endl;
cout<<myItoa(1024, str, 16)<<endl;
system("pause");
return 0;
}
itoa
最新推荐文章于 2025-10-09 22:00:00 发布
本文介绍了一个实用的C++函数myItoa,该函数能够将整数转换为不同进制的字符串表示形式,并包含了处理负数的功能。文章还提供了字符串反转的辅助函数以及主函数中的测试案例。
520

被折叠的 条评论
为什么被折叠?



