LeetCode_7.Reverse Integer

问题

Given a 32-bit signed integer, reverse digits of an integer.

Example 1:

Input: 123
Output: 321
Example 2:

Input: -123
Output: -321
Example 3:

Input: 120
Output: 21
Note:
Assume we are dealing with an environment which could only store integers within the 32-bit signed integer range: [−231, 231 − 1]. For the purpose of this problem, assume that your function returns 0 when the reversed integer overflows.

解题

def reverse(x):
    """
    :type x: int
    :rtype: int
    """
    y = -x if x < 0 else x

    list = []
    last = y
    while last > 0:
        list.append(last % 10)
        last //= 10

    sum = 0
    length = len(list)
    for l in list:
        length -= 1
        sum += l * 10 ** length

    result = -sum if x < 0 else sum

    if result > 2147483647 or result < -2147483648:
        return 0

    return result

思路

这里利用了不断对10作除法,所获得的余数顺序正好与原数字相反的特性。

posted @   Ken.W  阅读(136)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· Qt个人项目总结 —— MySQL数据库查询与断言
点击右上角即可分享
微信分享提示