c判断字符串是不是数字_C语言字符串与整数之间的转换,小白必会知识

在C语言中,我们经常面临需要将字符串转换为整型,以及将整型转化为字符串的问题。将字符串转换为整数的函数在stdlib.h中定义:

int atoi(const char *str);

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

2c219aad31c6e6bcfcc8fa9195ddda90.png

要注意的几点:

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

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

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

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

45324d7b0370d1d5b78f02c89425bdc1.png

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

char num[32];

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


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

#include <stdlib.h>. 这个是头文件

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

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

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


部分网友写的思路源码,把整数换成字符,sign判断正负数。

950b83d94ebde9f0ad31796c70fa76be.png

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

3563aab7ecdc4bfaf55aca5bc7d31d05.png

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

63988f942905653efc3b77756da49498.png


希望对你有帮助

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值