2020年7月24日 周五 天气贼热 【不悲叹过去,不荒废现在,不惧怕未来】
本文目录
题目简介
LeetCode 8. 字符串转换整数 (atoi)
这道题的难度虽然是中等,但不是很难,就是要考虑的情况有点多。
1. 大概思路
- 去掉前导空格
- 处理正负号
- 识别数字(注意越界情况)
2. 判断是否越界(重点)
如果只是简单地字符串转整数的话,就是简单地 ans = ans * 10 + digit。 但是注意这道题目可能会超过整数的最大表示, 也就是说会在某一步 ans * 10 + digit > INT_MAX 中 *10和 + digit 都有可能会越界,那么只要把这些都移到右边去就可以了。 因此,通过 ans > (INT_MAX - digit) / 10 判断是否越界就没问题了~
3. 完整代码
class Solution {
public:
int myAtoi(string s