字符串转成整数

示例1

输入:“42” 输出: 42

示例 2:

输入: " -42" 输出: -42 解释: 第一个非空白字符为 ‘-’, 它是一个负号。   我们尽可能将负号与后面所有连续出现的数字组合起来,最后得到 -42 。

示例 3:

输入: “4193 with words” 输出: 4193 解释: 转换截止于数字 ‘3’ ,因为它的下一个字符不为数字。

示例 4:

输入: “words and 987” 输出: 0 解释: 第一个非空字符是 ‘w’, 但它不是数字或正、负号。 因此无法执行有效的转换。

解法

  • 首部空格
  • 符号位 :三种情况,即 ‘’++’’ , ‘’-−’’ , ‘‘无符号" ;新建一个变量保存符号位,返回前判断正负即可;
  • 非数字字符: 遇到首个非数字的字符时,应立即返回;
  • 数字字符:
    1. 字符转数字: “此数字的 ASCII 码” 与 “ 00 的 ASCII 码” 相减即可;
    2. 数字拼接: 若从左向右遍历数字,设当前位字符为 cc ,当前位数字为 xx ,数字结果为 resres ,则数字拼接公式为: res=10×res+x
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
class Solution:
    def strToInt(self, str: str) -> int:
        str = str.strip()                      # 删除首尾空格
        if not str: return 0                   # 字符串为空则直接返回
        res, i, sign = 0, 1, 1
        int_max, int_min, bndry = 2 ** 31 - 1, -2 ** 31, 2 ** 31 // 10
        if str[0] == '-': sign = -1            # 保存负号
        elif str[0] != '+': i = 0              # 若无符号位,则需从 i = 0 开始数字拼接
        for c in str[i:]:
            if not '0' <= c <= '9' : break     # 遇到非数字的字符则跳出
            if res > bndry or res == bndry and c > '7': return int_max if sign == 1 else int_min # 数字越界处理
            res = 10 * res + ord(c) - ord('0') # 数字拼接
        return sign * res