leetcode 8 String to Integer (atoi)

class Solution {
public:
int myAtoi(string str) {
int i = 0, sign = 1, n = str.size();
long long result = 0;
//while (str[i] == " ")    //写错了 双引号表示的是字符串
while (str[i] == ' ')
{
i++;
}
//while (str[i] == '-' || str[i] == '+')
//{
if (str[i] == '-')
{
sign = -sign;
i++;
}
else if (str[i] == '+')
i++;
/* }*/
for (int j = i; j != n; j++)
{
if (str[j] >= '0' && str[j] <= '9')
result = result * 10 + (str[j] - '0');
else
{
if (result)
return result*sign;
else
return 0;
}


if (result > INT_MAX)
return sign == -1 ? INT_MIN : INT_MAX;
}
if (sign==-1)
return -result;
else
return result;
}

};

一开始题都没读懂,后来从网上看了看别人的,才知道只是转换string中的数字,不用考虑字母这些的转换(好像也不需要?)。

那这样就很好处理了,首先字符串中的空格要过滤掉,过滤的时候,空格要单引号(双引号是字符串)。在一个判断符号,之后就判断数字进行转换即可。

如果连续遇到正负号返回0。再加上判断是否超过INT_MAX。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值