一些itoa()函数
以下资料来自:http://www.ok2002.com/cc/cc/s.asp?r=a2273562157719
__rev()函数有一处错误,特复制过来进行更改:
//C++ itoa原型,itoa函数原型,转换正数为字符串,转换负数为字符串 /*--------- 1.转换正数为字符串 (1)用模运算的方法取得最后一位数,将这位数字转换为字符. (2)接着用整除的方法删除这位数字. 再取剩下数字的最后一位,转为字符,删除, 就这样直到将全部数字转为字符. (3)将'\0'之前的所有字符倒置即得到所要的字符串. 2.转换负数为字符串 (1)负数转换为正数处理. (2)处理完后,在'\0'之前添加字符'-'. (3)并将'\0'之前的全部字符倒置. ----------*/ #include<iostream> using namespace std; //反转字符串的指针版本 void __rev(char *s)//原函数 只有一位数的时候出错,如1 { char *p=s; char *q=s; char temp; while('\0'!=*(++q+1)); // cout<<*q<<endl; while(p<q) { if(*p!=*q) { temp=*p; *p=*q; *q=temp; } ++p; --q; } }
void __rev(char *s)//修改后的函数 { char *p=s; char *q=s; char temp; while('\0'!=*q)
{
++q;
}; --q; while(p<q) { if(*p!=*q) { temp=*p; *p=*q; *q=temp; } ++p; --q; } }
void itoa(int n,char *s) { int sign=n; if(sign<0) n=-n; int i=0; do { s[i++]=n%10+'0';//取最后一位数转换 n=n/10;//删除最后一位 }while(n>0); if(sign<0) s[i++]='-'; s[i]='\0'; __rev(s); } void main() { int a=-12345; char b[20]; itoa(a,b); cout<<b<<endl; } /*-- -12345 Press any key to continue --*/
另外还有能够选择进制的版本:
char *myitoa(int num,char*str,int radix)
{
char index[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
unsigned unum;
int i=0,j,k;
if(radix==10 && num<0)
{
unum=(unsigned)-num;
str[i++]='-';
}
else
unum=(unsigned)num;
do
{
str[i++]=index[unum%(unsigned)radix];
unum/=radix;
}while(unum);
str[i]='\0';
if(str[0]=='-')k=1;
else k=0;
for(j=k;j<(i-1)/2.0+k;j++)
{
num=str[j];
str[j]=str[i-j-1+k];
str[i-j-1+k]=num;
}//此处比较晦涩难懂
return str;
}