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;
}