leetcode-前300经典刷题-4(C++)

字符串转整数
这里我们主要需要考虑的就是内存越界问题,对于内存越界我们基本的思路就是将比较往前提一个周期。


class Solution {
public:
int myAtoi(string str) {
int res = 0;
int left;
int flag = 1;
int i = 0;
//去除空格
for(i;i<str.length();i++) {
if(str[i] == ’ ') {
continue;
}
break;
}
//判断符号
if(i<str.length()) {
// 这里以为多个±组合也可以
// while(i<str.length()) {
// if(str[i] == ‘-’) {
// flag *= -1;
// i++;
// }
// else if(str[i] == ‘+’) {

        //         i++;
        //     }
        //     else {
        //         break;
        //     }
        // }
        if(str[i] == '-') {
            flag *= -1;
            i++;
        }
        else if(str[i] == '+') {
            
            i++;
        }
        if(('a' <= str[i] && 'z' >= str[i]) || ('A' <= str[i] && 'Z' >= str[i])) {
            return 0;
        }
    }
    for(i;i<str.length();i++) {
        // 字符
        if(('a' <= str[i] && 'z' >= str[i]) || ('A' <= str[i] && 'Z' >= str[i]) || str[i] == ' ' || str[i] == '.' || str[i] == '+' || str[i] == '-') {
            break;
        }
        left = int(str[i] - '0') * flag;
        //越界
        if(left <= 0 && (INT_MIN - left)/10 >res) {
            return INT_MIN;
        }
        if(left >= 0 && (INT_MAX - left)/10 <res) {
            return INT_MAX;
        }
        res = res*10 + left;
        // for test
        // cout << res << endl;
    }
    return res;
}

};```


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值