/*--------- 1.转换正数为字符串 (1)用模运算的方法取得最后一位数,将这位数字转换为字符. (2)接着用整除的方法删除这位数字. 再取剩下数字的最后一位,转为字符,删除, 就这样直到将全部数字转为字符. (3)将'\0'之前的所有字符倒置即得到所要的字符串. 2.转换负数为字符串 (1)负数转换为正数处理. (2)处理完后,在'\0'之前添加字符'-'. (3)并将'\0'之前的全部字符倒置. ----------*/ #include<iostream> using namespace std; //反转字符串的指针版本 void __rev(char *s) { 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 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 --*/
C++ itoa原型,itoa函数原型,转换正数为字符串,转换负数为字符串
最新推荐文章于 2024-05-12 12:20:31 发布