打开网易新闻 查看精彩图片

在C语言中,我们经常面临需要将字符串转换为整型,以及将整型转化为字符串的问题。

将字符串转换为整数的函数在stdlib.h中定义:

int atoi(const char *str);

atoi函数会跳过str中前面出现的空格,从第一个数字开始转换。下面是我的实现:

打开网易新闻 查看精彩图片
打开网易新闻 查看精彩图片

要注意的几点:

1.参数检验。始终要放在最开始,在输入是指针的情况下,永远不要忘记首先检验是否是NULL指针;

2.字符串开始处的空格(我还加入了制表符)要注意跳过;

3.符号,不要忘了数字字符串第一个字符可能出现加号和减号!

对于将数字转换为字符串,c标准中并没有定义(itoa只是在一些编译器中自己定义)。c标准中没有定义的原因我觉得是数字转成字符串可以使用sprintf格式化输出函数来完成。当然我们可以自己编写一个itoa函数。这里的参数原型参照的是vc中定义的itoa:

打开网易新闻 查看精彩图片
打开网易新闻 查看精彩图片

当然,一般情况下我们使用sprintf就可以完成任务啦:

char num[32];

sprintf(num,"%d",12345);

C/C++中把字符串转换成整数,把整数转换成字符串

#include

. 这个是头文件

long atoi(char *); 这个是把字符转换整数

double atof(char *); 这个是转换浮点

char itoa(int i); 把整数转为字符串

itoa 网友写的思路源码,把整数换成字符,sign判断正负数,不过这

打开网易新闻 查看精彩图片

还有一个 ,这个函数有3个参数,第一转换的数,第二是转换后的字符,第三是进制,不过这个函数没有把STRING倒序

char * itoa(int value ,char *string, int radix)

char *psLetter="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";

while( value%radix != 0 )

*string++ = psLetter[value%radix];

value=value/radix;

*string=0;

下面这个用递归算法,解决倒序问题。VC6.0上测试可用。

#include

#include

char* itoa(int value ,char * string ,int radix)

if (value < 0)

*string = '-';

value = abs(value);

itoa(value,string+1,radix);

return string ;

if (value%radix == 0 && value/radix == 0) return string;

string = itoa(value/radix,string,radix);

if (value % radix >10) *string ='A'+value%radix-10;

else *string = '0' + value%radix;

*(string+1) = NULL;

return string+1;

void main(void)

int a;

char s[25];

a = -15;

itoa(a,s,10);

printf("%s",s);

getchar();