当前位置:网站首页>【LeetCode】zj面试-把字符串转换成整数
【LeetCode】zj面试-把字符串转换成整数
2022-08-03 08:51:00 【凝眸伏笔】
题目描述:
写一个函数 StrToInt,实现把字符串转换成整数这个功能。不能使用 atoi 或者其他类似的库函数。
- 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。
- 当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组合起来,作为该整数的正负号;假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数。
- 该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响。
- 注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换。
- 在任何情况下,若函数不能进行有效的转换时,请返回 0。
说明:
- 假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231, 231 − 1]。如果数值超过这个范围,请返回 INT_MAX (231 − 1) 或 INT_MIN (−231) 。
解题思路:
下四种字符需要考虑:
- 首部空格: 删除之即可;
- 符号位: 三种情况,即 ''++'' , ''-−'' , ''无符号" ;新建一个变量保存符号位,返回前判断正负即可。
- 非数字字符: 遇到首个非数字的字符时,应立即返回。
- 数字字符:
- 字符转数字: “此数字的 ASCII 码” 与 “ 00 的 ASCII 码” 相减即可;
- 数字拼接: 若从左向右遍历数字,设当前位字符为 cc ,当前位数字为 xx ,数字结果为 resres ,则数字拼接公式为:
- 数字边界处理:
在每轮数字拼接前,判断 resres 在此轮拼接后是否超过 21474836472147483647 ,若超过则加上符号位直接返回。
解题代码:
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
边栏推荐
猜你喜欢
Exception: Dataset not found. Solution
redis键值出现 xacxedx00x05tx00&的解决方法
36氪详情页AES
数据监控平台
机器学习(公式推导与代码实现)--sklearn机器学习库
Network LSTM both short-term and long-term memory
scala 并行集合、并行并发、线程安全问题、ThreadLocal
RSTP(端口角色+端口状态+工作机制)|||| 交换机接口分析
线程介绍与使用
AI mid-stage sequence labeling task: three data set construction process records
随机推荐
HCIA实验(07)
pytorch one-hot 小技巧
IDEA的database使用教程(使用mysql数据库)
sqlite date field plus one day
【论文笔记】一种基于启发式奖赏函数的分层强化学习方法
Guava的缓存
进程信息
Redis集群概念与搭建
C# 一周入门高级编程之《C#-继承》Day One
文章列表的显示 以及创建文章 还有文章详情的基本
uni-app 顶部选项卡吸附效果 demo(整理)
多线程下的单例模式
并发之多把锁和活跃性
分析型数据库性能测试总结
JMeter接口自动化发包与示例
牛客 - 鼠标的天选(字符串哈希)
【LeetCode】622. Design Circular Queue
ArcEngine (2) loading the map document
ArcEngine (5) use the ICommand interface to achieve zoom in and zoom out
多媒体数据处理实验3:图像特征提取与检索