itoa的实现

// num:待转换的整型变量   str:指向存放结果    radix:基数 
char* itoa1(int num, char *str, int radix)
{
const char table[] = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"; 
char *ptr = str;


if (num == 0)   
{   //数值为0时  
*ptr++ = '0';  
*ptr = '\0';  
return str;  



bool neg = false;
if (num < 0)
{
//数值小于0时,添加负号,并将指针后移 
neg = true;  
num *= -1;  
*ptr++ = '-'; 
}


while (num)   
{   
*ptr++ = table[num % radix];   
num /= radix;   

*ptr = '\0';
//反转字符串  
char *beg = (neg ? str +1 : str);
ptr--;  
while (beg < ptr)  
{   
int temp = *beg;   
*beg  = *ptr;   
*ptr  = temp;  
beg++;  
ptr--;  
}   
return str;   
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值