1 itoa的实现

//1234→4321(存储:str=n%radix,n=n/radix)→ 1234

//todo: 把含有 负数的内容写上去就好了

char * my_itoa2( int num, char *string, int radix )

{
char* str=string;

//得到翻转的字符串

while(num)
{
*str=num%radix+'0'; //*str=num%radix-'0'; 就是错误的了,哈哈。
//cout<<*str<<endl;
num=num/radix;
str++;
}
*str='\0';

char temp;

int len=strlen(str);
for(int i=0;i<len/2;i++)
{
temp=str[i];
str[i]=str[len-1-i];
str[len-1-i]=temp;
}
return string;
}

2 atoi的实现

// num=num*10+*str;

//todo:考虑 过界的情况。

int my_atoi( char *str )

{
if(str==NULL) return 0;
int num=0,flag=1;

if(*str=='-')

{
flag=-1;
}
else
{
num=*str-'0';
}
str++;

//while(*st>='0'&&*str<='9')

while(*str!='\0')
{
num=num*10+*str-'0';
str++;
}

return num*flag;

}

3 测试代码

int main()

{

char *s="-123567890";

cout<<my_atoi(s)<<endl;

int a=1234;

//*char str[20]={'\0'}; //需要预先定义好的
char *str=new char[20];
str=my_itoa2(a,str,10);
cout<<str<<endl;

return 0;

}