LeetCode 8. 字符串转换整数 (atoi)(判断是否越界是重点)

2020年7月24日 周五 天气贼热 【不悲叹过去,不荒废现在,不惧怕未来】



题目简介

LeetCode 8. 字符串转换整数 (atoi)
在这里插入图片描述
在这里插入图片描述
这道题的难度虽然是中等,但不是很难,就是要考虑的情况有点多。


1. 大概思路

  1. 去掉前导空格
  2. 处理正负号
  3. 识别数字(注意越界情况)

2. 判断是否越界(重点)

如果只是简单地字符串转整数的话,就是简单地 ans = ans * 10 + digit。 但是注意这道题目可能会超过整数的最大表示, 也就是说会在某一步 ans * 10 + digit > INT_MAX 中 *10和 + digit 都有可能会越界,那么只要把这些都移到右边去就可以了。 因此,通过 ans > (INT_MAX - digit) / 10 判断是否越界就没问题了~

3. 完整代码

class Solution {
   
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值