华为机考攻略(python)--字符串操作【9题】(第九题NC100字符串转换成整数)

57 篇文章 4 订阅

系列文章目录


前言

一、NC100字符串转换成整数

描述: 写一个函数StrToInt,实现把字符串转换成整数的功能。不能使用atoi或其它类似的库函数。传入的字符串可能有
以下部分组成:
1.若干空格
2.(可选)一个符号字符(‘+‘或’-’)
3.数字,字母,符号,空格组成的字符串表达式
4.若干空格
转换算法如下:
1.去掉无用的前导空格
2.第一个非空字符为+或-时,作为该整数的正负号,如果没有符号,默认为正数
3.判断整数的有效部分
3.1确定符号位之后,与之后面尽可能多的连续数字组合起来成为有效整数数字,如果没有有效的整数部分,那么返回0
3.2将字符串起前面的整数部分取出,后面可能会存在多余的字符(字母,符号,空格等),这些字符可以忽略
3.3整数超过32位有符号整数范围[-2** 31,2**31-1],需要截断这个整数,使其保持在这个范围内
4.去掉无用的后导空格
数据范围:
0<=字符串长度<=100
字符串由英文字母(大写和小写),数字(0-9),“、”,“+”,“-“组成
示例1:
输入:“82”
返回值:82
示例2:
输入:” -12 "
返回值:-12 #去掉前后的空格
示例3:
输入:“4396 clearlove”
返回值:4396
说明:6后面的字符不属于有效的整数部分,要去除
示例4:
输入:“clearlove 4396”
返回值:0
示例5:
输入:”-987654321111"
返回值:-2147483648

二、sound code

代码如下(示例):

import re
class Solution:
    def StrToInt(self , s: str) -> int:
        # write code here
        s = s.strip()
        if s == '' or s[0] not in '+-0123456789': return 0
        numelem = re.split('[a-zA-z\.\s+-]',s)
        numelem = numelem[0] if numelem[0] != '' else numelem[1]
        if numelem == '': return 0
        if s[0] == '-': return -min(int(numelem),2**31)
        return min(int(numelem),2**31-1)
s = Solution()
print(s.StrToInt(input()))

总结

分享:
夕阳不是沉落,而是预示着明天的太阳升起!对抗岁月的方法是进攻而非防守,让自己用心去捕捉事物的本质,努力去还原它们的本相。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

若竹之心

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值