实现 atoi,将字符串转为整数。

在找到第一个非空字符之前,需要移除掉字符串中的空格字符。如果第一个非空字符是正号或负号,选取该符号,并将其与后面尽可能多的连续的数字组合起来,这部分字符即为整数的值。如果第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数。

字符串可以在形成整数的字符后面包括多余的字符,这些字符可以被忽略,它们对于函数没有影响。

当字符串中的第一个非空字符序列不是个有效的整数;或字符串为空;或字符串仅包含空白字符时,则不进行转换。

若函数不能执行有效的转换,返回 0。

说明:

假设我们的环境只能存储 32 位有符号整数,其数值范围是 [−2^31,  2^31 − 1]。如果数值超过可表示的范围,则返回  INT_MAX (2^31 − 1) 或 INT_MIN (−2^31) 。

示例 1:

输入: "42"
输出: 42

示例 2:

输入: "   -42"
输出: -42
解释: 第一个非空白字符为 '-', 它是一个负号。
  我们尽可能将负号与后面所有连续出现的数字组合起来,最后得到 -42 。

示例 3:

输入: "4193 with words"
输出: 4193
解释: 转换截止于数字 '3' ,因为它的下一个字符不为数字。

示例 4:

输入: "words and 987"
输出: 0
解释: 第一个非空字符是 'w', 但它不是数字或正、负号。
因此无法执行有效的转换。

示例 5:

输入: "-91283472332"
输出: -2147483648
解释: 数字 "-91283472332" 超过 32 位有符号整数范围。
  因此返回 INT_MIN (−231) 。
class Solution {
public:
int myAtoi(string str)
{
if(str.empty())
{
return 0;
}
int i=0,out=0;
int flag=1;
while(isspace(str[i]))
{
i++;
}
if(str[i]=='-')
{
flag=-1;
i++;
}
else if(str[i]=='+')
{
flag=1;
i++;
}
while(i<str.size())
{
if(isdigit(str[i]))
{
if(out>INT_MAX/10)
{
if(flag>0)
return INT_MAX;
else
return INT_MIN;
break;
}
else if(out==INT_MAX/10 && str[i]-'0'>7)
{
return (flag>0)? INT_MAX : INT_MIN;
}
else
{
out = out * 10;
out+=str[i]-'0';
i++;
}
}
else
break;
}
return out*flag;
}
};

C提供了atoi函数,可以将字符串转为整数,但是并不是在所有的编译器中都可以使用,所以很多情况下,需要我们自己去实现这个功能,正好也可以搞清楚库函数atoi内部是怎么实现的。

上述自己编写的程序思路如下:(1)首先判断字符串是否为空,如果是空,则返回0;(2)字符串不为空时,继续利用isspace函数将一开始的空格,tab键字符等跳过;(3)如果第一个非数字字符是,正负号,则代表数字的正负,这里要同时判断,否则处理“-+1”这种字符串会出错。(4)接着判断后面是不是数字,如果不是,则返回0,如果是,则进行处理再一直往后遍历,直到碰见第一个非数字字符停止。(5)越界判断,这里很绕。要特别注意INT_MAX,INT_MIN周围的特殊的数字。

优秀代码如下:

class Solution {
public:
int myAtoi(string str)
{
if (str.empty()) return 0;
int sign = 1, base = 0, i = 0, n = str.size();
while (i < n && str[i] == ' ') ++i;
if (str[i] == '+' || str[i] == '-')
{
sign = (str[i++] == '+') ? 1 : -1;
}
while (i < n && str[i] >= '0' && str[i] <= '9')
{
if (base > INT_MAX / 10 || (base == INT_MAX / 10 && str[i] - '0' > 7))
{
return (sign == 1) ? INT_MAX : INT_MIN;
}
base = 10 * base + (str[i++] - '0');
}
return base * sign;
}
};

思想是一样的,但是这段代码写的更加简洁

最新文章

  1. C# 模板列在绑定的时候取文本值
  2. [转] C++的引用传递、指针传递参数在java中的相应处理方法
  3. c++ insert iterators 插入型迭代器
  4. 巧用ifstream判断文件是否存在
  5. linux 免交互状态下修改用户密码
  6. openfire 介绍安装使用
  7. 实例源码--Android简单音乐播放器源码
  8. Hdu 2979 Expensive Drink
  9. [Twisted] transport和protocol解耦
  10. jdbc3
  11. HTML5图片上传本地预览
  12. FastReport编程方式给Picture控件赋值
  13. node.js一行一行的获取txt文件内容
  14. VysorPro助手
  15. re正则匹配
  16. spring mvc 中web.xml配置信息解释
  17. centos安装图形化界面
  18. 蝉知CMS本地迁移到服务器具体步骤
  19. vue2.0模拟锚点
  20. VScode 光标乱跳

热门文章

  1. StringBuilder和输入输出
  2. 判断最长回文串——暴力、延展、Manacher
  3. 庐山真面目之十一微服务架构手把手教你搭建基于Jenkins的企业级CI/CD环境
  4. pytest fixtures装饰器的使用
  5. Linux更换软件源
  6. error out of table range
  7. 【题解】洛谷P3119 Grass Cownoisseur G
  8. 11.15 gryz校测(题解分析报告)
  9. jQuery——操作DOM
  10. JVM 线上故障排查