atoi和itoa函数的实现方法
atoi的实现:
#include<iostream>
using namespace std;
int atio1(char *s)
{
int sign=1,num=0;
if(*s=='-')
sign=-1;
s++;
while((*s)!='\0')
{
num=num*10+(*s-'0');
s++;
}
return num*sign;
}
itoa的实现:
法1:
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] != '-') //如果不是负数,则需要把数字字符下标左移一位
{
for(i=0; str[i+1]!='\0'; i++)
str[i] = str[i+1];
str[i] = '\0';
}
}
法2:
char *itoa(int num, char *str, int radix)
{
char* ptr = str;
int i;
int j;
while (num)
{
*ptr++ = string[num % radix];
num /= radix;
if (num < radix)
{
*ptr++ = string[num];
*ptr = '\0';
break;
}
}
j = ptr - str - 1;
for (i = 0; i < (ptr - str) / 2; i++)
{
int temp = str[i];
str[i] = str[j];
str[j--] = temp;
}
return str;
}
最新文章
- [转]SecureCRT使用配置详细图文教程
- 1965: [Ahoi2005]SHUFFLE 洗牌 - BZOJ
- 解决IE下jquery ajax无法获得最新数据的问题(IE缓存)
- POJ 3191 The Moronic Cowmpouter(进制转换)
- Zookeeper实战之单机集群模式
- Re-installation failed due to different application signatures./package name has exist
- OpenSuSE zypper OpenStack Icehouse repoAdd
- Excel如何进行SVN
- HDU 2067 小兔的棋盘
- PHP关于表单提交 后 post get分页
- salt基本使用之一(1)
- 配置CLion作为Qt5开发环境
- 系统功能调用Windows操作系统原理实验
- 解决关于 vue项目中 点击按钮路由多了个问号
- Jenkins结合.net平台工具之ReportGenerator
- HostAliases向Pod中添加hosts解析
- ServiceMesh了解一下
- mac电脑设置USB键盘按键方法,设置多显示屏镜像显示器的方法
- Linux下MySQL5.7.18二进制包安装(手动添加配置文件my_default.cnf)
- .NET Core 跨平台 串口通讯 ,Windows/Linux 串口通讯,flyfire.CustomSerialPort 的使用