leetcode的python实现 刷题笔记7: 反转整数

给定一个 32 位有符号整数,将整数中的数字进行反转。

示例 1:

输入: 123
输出: 321

 示例 2:

输入: -123
输出: -321

示例 3:

输入: 120
输出: 21

注意:

假设我们的环境只能存储 32 位有符号整数,其数值范围是 [−231,  231 − 1]。根据这个假设,如果反转后的整数溢出,则返回 0。

class Solution(object):
    def reverse(self, x):
        """
        :type x: int
        :rtype: int
        """
        # 判断是否为个位数,是个位数则不用反转,直接返回
        if -10 < x < 10:
            return x
        # 把整数x转为字符串
        string = str(x)
        # 判断第一个是否为负号
        if string[0] != "-":
            # 不是负号则直接反转
            string = string[::-1]
            # str转为int
            x = int(string)
        else:
            # 是负号,则反转负号之后的字符串
            string = string[1:][::-1]
            # str转int
            x = int(string)
            # 加上负号
            x = -x
        # 判断是否溢出
        # 如果-2147483648 < x < 2147483647则返回x,否则返回0
        return x if -2147483648 < x < 2147483647 else 0

# 总结反思
'''
1.访问子字符串,可以使用方括号来截取字符串,例如string[0]取的是字符串第一个元素
2.[ : ]    截取字符串中的一部分,string[::-1]表示从尾到头翻转,步长为-1
3.int类型中如果首元素是0,则忽略
'''具体字符串复习:python学习笔记:string模块,字符串的常用方法以及字符串常量示例

猜你喜欢

转载自blog.csdn.net/weixin_41931602/article/details/82811127
今日推荐