itoa以及atoi兩個函數實現應該是面試中的常見題,現在先預備寫兩個,以便需要的時候的快速反應
[cpp] //返回0表示出錯
int atoi(char* str)
{
int len=lstrlenA(str);
int ret=0;
int i=0;
if('-'==str[0]||'+'==str[0])
{
i=1;
}
for(;i<len;++i)
{
if(str[i]<'0'||str[i]>'9')
{
ret=0;
break;
}
ret=ret*10+(str[i]-'0');
}
if('-'==str[0])
{
ret=~ret+1;
}
return ret;
}
char* itoa(int n,char *str,int radix)
{
static char X[16]={'0','1',
'2','3',
'4','5',
'6','7',
'8','9',
'A','B',
'C','D',
'E','F'
};
int i=0;
while(1)
{
if(radix==16)
str[i]=X[n%radix];
else
str[i]=n%radix+'0';
if((n/=radix)==0)
break;
++i;
}
for(int j=0;j<(i+1)/2;++j)
{
char c=str[j];
str[j]=str[i-j];
str[i-j]=c;
}
return str;
}
//返回0表示出錯
int atoi(char* str)
{
int len=lstrlenA(str);
int ret=0;
int i=0;
if('-'==str[0]||'+'==str[0])
{
i=1;
}
for(;i<len;++i)
{
if(str[i]<'0'||str[i]>'9')
{
ret=0;
break;
}
ret=ret*10+(str[i]-'0');
}
if('-'==str[0])
{
ret=~ret+1;
}
return ret;
}
char* itoa(int n,char *str,int radix)
{
static char X[16]={'0','1',
'2','3',
'4','5',
'6','7',
'8','9',
'A','B',
'C','D',
'E','F'
};
int i=0;
while(1)
{
if(radix==16)
str[i]=X[n%radix];
else
str[i]=n%radix+'0';
if((n/=radix)==0)
break;
++i;
}
for(int j=0;j<(i+1)/2;++j)
{
char c=str[j];
str[j]=str[i-j];
str[i-j]=c;
}
return str;
}
摘自 天道酬勤