[AcWing 87] 把字符串转换成整数

image


点击查看代码
class Solution {
public:
    int strToInt(string str) {
        int k = 0;
        while (k < str.size() && str[k] == ' ')     k++;
        long long res = 0;
        int minus = 1;
        if (k < str.size()) {
            if (str[k] == '-')      minus *= -1, k++;
            else if (str[k] == '+')    k++;
        }
        while (k < str.size() && str[k] >= '0' && str[k] <= '9') {
            res = res * 10 + str[k] - '0';
            if (res > 1e11)     break;
            k++;
        }
        res *= minus;
        if (res > INT_MAX)  res = INT_MAX;
        if (res < INT_MIN)  res = INT_MIN;
        return res;
    }
};

  1. 每条边界条件都要处理好;
  2. res 定义为 long long;
  3. minus 用于记录正负;
  4. res 在 while 中用于记录结果的绝对值,当 res 很大 (res > 1e11) 时退出 while;
posted @ 2022-04-21 23:11  wKingYu  阅读(34)  评论(0)    收藏  举报