将一个字符串转换为整型数的实现
2013-05-22 15:35
197 查看
描述:写一个函数,实现输入一个表示整数的字符串,把该字符串转换成整数并输出,即实现库函数int atoi(char * str).
分析:此题目可能要考虑以下几点:1.函数参数str不能为NULL;2.字符串以若干空格字符开头;3.符号位可能有正负之分;4.溢出,即数字超出了INT_MIN~INT_MAX, 尤其要考虑这两个范围并不是对称的;5.字符串中包含了不是数字的字符。综合以上考虑,本文给出一个此函数的一个C实现.
//atoi: convert a string to int
int atoi(char * str)
{
unsigned int num;
int sign;
assert(str != NULL);
//跳过开头的空字符
while(isspace(*str))
{
str++;
}
//检查符号位
sign = (*str == '-') ? -1 : 1;
//跳过符号位
if (*str == '+' || *str == '-')
{
str++;
}
//依次处理每位字符
for (num = 0; isdigit(*str); str++)
{
num = 10 * num + (*str - '0');
//处理当数字为INT_MIN时
if ( num == INT_MAX+1 && sign == -1)
return INT_MIN;
//溢出检查
assert(num <= INT_MAX);
}
return sign * (int)num;
}
参考文献:《The C Programming language》
分析:此题目可能要考虑以下几点:1.函数参数str不能为NULL;2.字符串以若干空格字符开头;3.符号位可能有正负之分;4.溢出,即数字超出了INT_MIN~INT_MAX, 尤其要考虑这两个范围并不是对称的;5.字符串中包含了不是数字的字符。综合以上考虑,本文给出一个此函数的一个C实现.
//atoi: convert a string to int
int atoi(char * str)
{
unsigned int num;
int sign;
assert(str != NULL);
//跳过开头的空字符
while(isspace(*str))
{
str++;
}
//检查符号位
sign = (*str == '-') ? -1 : 1;
//跳过符号位
if (*str == '+' || *str == '-')
{
str++;
}
//依次处理每位字符
for (num = 0; isdigit(*str); str++)
{
num = 10 * num + (*str - '0');
//处理当数字为INT_MIN时
if ( num == INT_MAX+1 && sign == -1)
return INT_MIN;
//溢出检查
assert(num <= INT_MAX);
}
return sign * (int)num;
}
参考文献:《The C Programming language》
相关文章推荐
- 在Python中,如何将一个字符串数组转换成整型数组
- LeetCode[实现一个字符串转换为整型变量]
- 编写函数实现:整型数转换成字符串
- 将一个整型数组里面的元素转换成字符串类型
- c语言实现将一个整数转换为字符串
- 实现一个函数stringToInt,实现把字符串转换成整数这个功能
- 实现一个函数int my_atoi(char s[]),可以将一个字符串转换为对应的整数
- //实现一个atoi的函数,atoi是将字符串转换成整数
- 【剑指offer】C语言:实现函数可以将一个字符串转换为对应的整数,如+1234输出1234
- 一个字符为0~9的字符串转换成整型数组中数值的对应的形式
- 自己实现的一个字符串编码类型转换的类(VC)
- 一个javascript的Math对象的方法实现,将字符串,转换成实际函数
- 怎样将一个整型值转换为一个字符串?(C++方法)
- C/C++浮点数的存储方式,以及实现一个ftoa函数将浮点数转换为字符串
- 实现一个函数int my_atoi(char s[]),可以将一个字符串转换为对应的整数
- C++中sprintf实现将一个基本数据类型的数组转换成字符串
- 实现一个函数int my_atoi(char s[]),可以将一个字符串转换为对应的整数。
- 递归法实现整型数到字符串的转换
- 请写一个函数,实现以下功能: 字符串“open_door” 转换成 “OpenDoor”、”make_by_id” 转换成 ”MakeById”
- 用c语言实现 编写一个函数,将一个数字字符串转换成这个字符串对应的数字(包括正浮点数、负浮点数)