码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【LeetCode】zj面试-把字符串转换成整数


    题目:剑指 Offer 67. 把字符串转换成整数

    题目描述:

    写一个函数 StrToInt,实现把字符串转换成整数这个功能。不能使用 atoi 或者其他类似的库函数。

    • 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。
    • 当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组合起来,作为该整数的正负号;假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数。
    • 该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响。
    • 注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换。
    • 在任何情况下,若函数不能进行有效的转换时,请返回 0。

    说明:

    • 假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231,  231 − 1]。如果数值超过这个范围,请返回  INT_MAX (231 − 1) 或 INT_MIN (−231) 。

    解题思路:

    下四种字符需要考虑:

    1. 首部空格: 删除之即可;
    2. 符号位: 三种情况,即 ''++'' , ''-−'' , ''无符号" ;新建一个变量保存符号位,返回前判断正负即可。
    3. 非数字字符: 遇到首个非数字的字符时,应立即返回。
    4. 数字字符:
      1. 字符转数字: “此数字的 ASCII 码” 与 “ 00 的 ASCII 码” 相减即可;
      2. 数字拼接: 若从左向右遍历数字,设当前位字符为 cc ,当前位数字为 xx ,数字结果为 resres ,则数字拼接公式为:

    1.  数字边界处理:

      在每轮数字拼接前,判断 resres 在此轮拼接后是否超过 21474836472147483647 ,若超过则加上符号位直接返回。

    解题代码:

    1. class Solution:
    2. def strToInt(self, str: str) -> int:
    3. str = str.strip() # 删除首尾空格
    4. if not str: return 0 # 字符串为空则直接返回
    5. res, i, sign = 0, 1, 1
    6. int_max, int_min, bndry = 2 ** 31 - 1, -2 ** 31, 2 ** 31 // 10
    7. if str[0] == '-': sign = -1 # 保存负号
    8. elif str[0] != '+': i = 0 # 若无符号位,则需从 i = 0 开始数字拼接
    9. for c in str[i:]:
    10. if not '0' <= c <= '9' : break # 遇到非数字的字符则跳出
    11. if res > bndry or res == bndry and c > '7': return int_max if sign == 1 else int_min # 数字越界处理
    12. res = 10 * res + ord(c) - ord('0') # 数字拼接
    13. return sign * res

  • 相关阅读:
    看三年的CRUD程序员如何解决数据库死锁的
    主线程调用return和pthread_exit有什么区别?
    ubuntu 20.04 + 3090Ti 深度学习装机 (Nvidia-显卡驱动-515.57 + CUDA-11.7 + cuDNN-8.4.1)
    【C++】C 语言与 C++ 语言的关系 ( C 语言发展 | C 语言缺陷 | C 语言 + 面向对象 + 高级语言特性 | C++ 语言增加内容 | C 语言与 C++ 语言应用场景 )
    网络安全(黑客)自学
    数据库系统概论(超详解!!!) 第三节 关系数据库标准语言SQL(Ⅳ)
    Python基础——list列表
    [网络工程师]-应用层协议-SNMP
    JS事件循环
    邮件安全不容忽视,教你如何防止邮件泄密!
  • 原文地址:https://blog.csdn.net/pearl8899/article/details/126025361
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号