LeetCode第七题: 整数反转

题目描述

给你一个 32 位的有符号整数 x​ ,返回将 x​ 中的数字部分反转后的结果。

如果反转后整数超过 32 位的有符号整数的范围 [−2^31, 2^31 − 1]​ ,就返回 0。

假设环境不允许存储 64 位整数(有符号或无符号)。

示例

给定一个32位的整数,你需要将这个整数中的每一对数字反转。如果反转后整数超过32位,你应当在前导数字中用0填充,以得到一个有效的32位整数。假设我们的环境只能存储32位大小的有符号整数,其数值范围是 [−2^31, 2^31 − 1]。你可以假设输入的数字不会超过这个范围。

解题思路 - 数字反转法

要反转一个整数,我们可以先将整数转换为字符串,然后反转字符串,最后将反转后的字符串转换回整数。但是这种方法可能会因为整数太大而超出32位整数的范围。因此,我们需要使用数学方法来反转数字,通过逐步构建反转后的整数,并确保每一步的结果都在32位整数的范围内。

Go语言实现 - 数字反转法

go 复制代码
func reverse(x int) int {
    var result int = 0
    sign := 1
    if x < 0 {
        sign = -1
        x = -x
    }
    for x > 0 {
        pop := x % 10
        x /= 10
        if result > (1<<31-1)/10 || (result == (1<<31-1)/10 && pop > 7) {
            return 0 // 反转后的数超出32位整数范围
        }
        if result < -1<<31 {
            return 0 // 反转后的数超出32位整数范围
        }
        result = result*10 + pop
    }
    return result * sign
}

算法分析

  • 时间复杂度: O(log10(n)),因为我们需要遍历整数的每一位数字。
  • 空间复杂度: O(1),我们只使用了常数级别的额外空间。

这段代码首先检查输入的整数是否为负数,如果是,我们将其转换为正数并在最后应用符号。然后,我们通过循环遍历整数的每一位,将其添加到结果中。在每一步,我们都要检查结果是否超出了32位整数的范围。如果超出,我们返回0。最后,我们将结果乘以原始整数的符号,得到最终答案。

当然,除了上述的数学方法,我们还可以采用一种更直观的位操作的方法来解决这个问题。这种方法不依赖于数字的十进制表示,而是直接在二进制层面上进行操作。以下是使用位操作的Go语言实现:

Go语言实现 - 位操作法

go 复制代码
func reverse(x int) int {
    var result int = 0
    for x != 0 {
        pop := x % 10 // 获取最低位
        x /= 10       // 移除最低位

        // 检查结果是否可能溢出
        if result > (1<<31-1)/10 || (result == (1<<31-1)/10 && pop > 7) {
            return 0
        }
        if (result * 10) > (1<<31-1) || (result * 10) + pop < -(1<<31) {
            return 0
        }

        result = result*10 + int(pop)
    }
    return result
}

算法分析

  • 时间复杂度: O(log10(n)),因为我们需要遍历整数的每一位数字。
  • 空间复杂度: O(1),我们只使用了常数级别的额外空间。

在这个版本中,我们使用了一个循环来逐位处理输入的整数。在每次迭代中,我们取出最低位的数字(pop),然后将其加到结果(result)上。同时,我们需要检查在每一步操作后,结果是否可能溢出32位整数的范围。如果会溢出,我们返回0。如果不溢出,我们继续处理下一位数字。

这种方法的优点是它不依赖于数字的十进制表示,因此不受数字大小的限制。它直接在二进制层面上进行操作,这使得它在处理非常大的整数时更加可靠。

相关推荐
shymoy14 分钟前
Radix Sorts
数据结构·算法·排序算法
风影小子23 分钟前
注册登录学生管理系统小项目
算法
黑龙江亿林等保25 分钟前
深入探索哈尔滨二级等保下的负载均衡SLB及其核心算法
运维·算法·负载均衡
起名字真南27 分钟前
【OJ题解】C++实现字符串大数相乘:无BigInteger库的字符串乘积解决方案
开发语言·c++·leetcode
lucy1530275107928 分钟前
【青牛科技】GC5931:工业风扇驱动芯片的卓越替代者
人工智能·科技·单片机·嵌入式硬件·算法·机器学习
杜杜的man44 分钟前
【go从零单排】迭代器(Iterators)
开发语言·算法·golang
小沈熬夜秃头中୧⍤⃝1 小时前
【贪心算法】No.1---贪心算法(1)
算法·贪心算法
木向2 小时前
leetcode92:反转链表||
数据结构·c++·算法·leetcode·链表
阿阿越2 小时前
算法每日练 -- 双指针篇(持续更新中)
数据结构·c++·算法
skaiuijing2 小时前
Sparrow系列拓展篇:对调度层进行抽象并引入IPC机制信号量
c语言·算法·操作系统·调度算法·操作系统内核