atoi 和 itoa实现
2016-03-05 11:28
381 查看
<span style="font-size:18px;">#include<stdio.h> int atoi(const char *str) { int value=0; bool b_plus=true; //判断符号 switch(*str) //过滤符号 { case '+': str++; break; case '-': b_plus=false; str++; break; default: break; } while('\0' != *str) { value = (value*10)+(*str-'0'); str++; } if(!b_plus) value=-value; return value; } void main() { char str[]="-999"; int value=atoi(str); printf("The result is:%d\n",value); }</span>
<span style="font-size:18px;"></span><pre name="code" class="cpp">#include<stdio.h> void itoa(int value, char *str) { if (value < 0) //如果是负数,则str[0]='-',并把value取反(变成正整数) { str[0] = '-'; value = 0-value; } int i,j; for(i=1; value > 0; i++,value/=10) //从value[1]开始存放value的数字字符,不过是逆序,等下再反序过来 str[i] = value%10+'0'; //将数字加上0的ASCII值(即'0')就得到该数字的ASCII值 for(j=i-1,i=1; j-i>=1; j--,i++) //将数字字符反序存放 { str[i] = str[i]^str[j]; str[j] = str[i]^str[j]; str[i] = str[i]^str[j]; } if(str[0] != '-') //如果不是负数,则需要把数字字符下标左移一位,即减1 { for(i=0; str[i+1]!='\0'; i++) str[i] = str[i+1]; str[i] = '\0'; } } void main() { int value = -1212345; char str[10] = {'\0'}; //记得把str全填充为'\0' itoa(value, str); printf("The result is:%s\n", str); }
相关文章推荐
- C++类的静态成员(static members in classes)
- 面试题
- sql server存储过程编程
- Did not find handler method for springMVC资源文件扫描不到---关于spring的那些坑
- 3n+1问题
- 解决gradle运行gradle -v命令报Fialed to laod library 'native-platform.dll'错误
- 中医香口方
- 字符集与编码系列 1-9
- ios获取权限
- 父亲浮动,子代也会跟着走
- Android学习笔记----常用adb指令
- tomcat的log文件夹下不生成log文件的问题
- 闭包
- 递归第一次
- SurfaceView的双缓冲机制
- 妖股是如何炼成的?
- 动态规划算法浅析
- 内联元素和块元素
- YAML使用教程 (snakeyaml-1.12.jar)
- android 密码显示与隐藏的切换