一些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;

}

 
posted @ 2012-11-21 11:58  枫部落  阅读(1652)  评论(0编辑  收藏  举报
点击这里给我发消息