LeetCode刷题第7题【整数反转】---解题思路及源码注释

news/2025/2/15 12:32:49/

LeetCode刷题第7题【整数反转】—解题思路及源码注释

结果预览

代码执行效果

目录

  • LeetCode刷题第7题【整数反转】---解题思路及源码注释
    • 结果预览
    • 一、题目描述
    • 二、解题思路
      • 1、问题理解
      • 2、解题思路
    • 三、代码实现及注释
      • 1、源码实现
      • 2、代码解释
    • 四、执行效果
      • 1、时间和空间复杂度分析

一、题目描述

给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。
如果反转后整数超过 32 位的有符号整数的范围 [−231, 231 − 1] ,就返回 0。
假设环境不允许存储 64 位整数(有符号或无符号)。

示例 1:

输入:x = 123
输出:321

示例 2:

输入:x = -123
输出:-321

示例 3:

输入:x = 120
输出:21

示例 4:

输入:x = 0
输出:0

提示:

-231 <= x <= 231 - 1

二、解题思路

1、问题理解

该问题的关键在于如何处理整数反转,并且避免在反转过程中超出 32 位整数的范围。

2、解题思路

  • 问题分析
    该问题的关键在于如何处理整数反转,并且避免在反转过程中超出 32 位整数的范围。具体的步骤如下:
    • 反转数字:通过取余和除法的方法提取数字的每一位,然后将其反转。
    • 溢出处理:在反转过程中,我们需要检查是否超出了 32 位有符号整数的范围。
    • 负数的处理:我们需要正确处理负数,反转时应保留负号。
  • 步骤:
    • 处理负数:如果输入的数字是负数,则反转后的结果应该保留负号。可以在反转完成后加上负号。
    • 反转数字:利用取余和除法,我们可以从数字的末尾开始获取每一位,依次构建反转后的数字。
    • 溢出判断:在反转过程中,如果结果超过了 2^31 - 1(即 2147483647)或小于 -2^31(即 -2147483648),则返回 0。
  • 细节:
    • 负数:处理负数时,可以先将其转换为正数进行处理,最后再加上负号。
    • 溢出:反转时,我们需要判断反转的结果是否会超出 32 位整数的范围。在每次计算反转时,可以在放入新数字前判断是否会溢出。

三、代码实现及注释

1、源码实现

class Solution {
public:int reverse(int x) {int result = 0;while (x != 0) {int digit = x % 10;  // 提取最后一位数字x /= 10;  // 去除最后一位数字// 判断是否会溢出if (result > INT_MAX / 10 || (result == INT_MAX / 10 && digit > 7)) {return 0;  // 超出正整数的范围}if (result < INT_MIN / 10 || (result == INT_MIN / 10 && digit < -8)) {return 0;  // 超出负整数的范围}result = result * 10 + digit;  // 将数字加到反转结果的末尾}return result;}
};

2、代码解释

  • reverse 函数:
    • 该函数的作用是反转给定的整数 x,并返回反转后的结果。
  • while (x != 0):
    • 我们在循环中处理每一位数字,直到 x 为 0。
  • int digit = x % 10:
    • 获取当前数字的最后一位。
  • x /= 10:
    • 去除数字的最后一位,准备处理下一位。
  • 溢出判断:
    • 判断是否会溢出:
      • 如果 result 大于 INT_MAX / 10 或者 result 等于 INT_MAX / 10 且当前数字 digit 大于7,那么反转会超出正整数的范围。
      • 如果 result 小于 INT_MIN / 10 或者 result 等于 INT_MIN / 10 且当前数字 digit 小于-8,那么反转会超出负整数的范围。
  • result = result * 10 + digit:
    • 将当前数字添加到 result 的末尾,形成反转后的结果。
  • 返回结果:
    • 当 x 为 0 时,退出循环并返回反转后的结果。

四、执行效果

代码执行效果

1、时间和空间复杂度分析

  • 时间复杂度:O(log(x)),其中 x 是整数的绝对值。每次通过取余操作去掉 x 的一位数字,因此需要 O(log(x)) 次操作。
  • 空间复杂度:O(1),我们只使用了常数空间来存储 result 和 digit。

http://www.ppmy.cn/news/1572237.html

相关文章

win10右键使用IDEA打开

win10右键使用IDEA打开 问题修改注册表 问题 电脑重装系统之后&#xff0c; 在文件夹中右键缺失了使用IDEA打开项目的快捷操作&#xff0c; 这里记录一下怎么恢复。 修改注册表 使用winR打开运行&#xff0c;输入regedit点击确定&#xff0c;进入注册表。 找到路径计算机\HK…

C++-----------酒店客房管理系统

酒店客房管理系统 要求&#xff1a; 1.客房信息管理:包括客房的编号、类型、价格、状态等信息的录入和修改; 2.顾客信息管理:包括顾客的基本信息、预订信息等的管理; 3.客房预订:客户可以根据需要进行客房的预订&#xff0c;系统会自动判断客房的可用情况; 4.入住管理:客户入住…

/etc/sysctl.conf——系统的配置文件

用户级修改 控制当前会话的文件描述符数量(一般打开一个终端就是一个会话) # 设置软限制&#xff08;当前会话中可使用的最大文件描述符数&#xff09; ulimit -Sn 65535 # 设置硬限制&#xff08;软限制的上限&#xff09; ulimit -Hn 65535控制核文件大小 ulimit -c unlim…

STL语言在工业自动化中的价值与应用场景分析

STL语言在工业自动化中的价值与应用场景分析 引言 作为西门子PLC编程的核心语言&#xff0c;STL&#xff08;Statement List&#xff09;凭借其底层控制能力&#xff0c;长期在工业自动化领域占据重要地位。然而&#xff0c;随着LAD、FBD、SCL等高级语言的普及&#xff0c;关…

算法跟练第十弹——栈与队列

文章目录 part01 逆波兰表达式求值part02 滑动窗口最大值part03 前 K 个高频元素归纳&#xff1a;将字符串转转换成整数&#xff1a;LinkedListMap遍历优先级队列的比较器 跟着代码随想录刷题的第十天。 代码随想录链接&#xff1a;代码随想录 part01 逆波兰表达式求值 题目链接…

缓存的介绍

相关面试题 &#xff1a; ● 为什么要用缓存&#xff1f; ● 本地缓存应该怎么做&#xff1f; ● 为什么要有分布式缓存?/为什么不直接用本地缓存? ● 为什么要用多级缓存&#xff1f; ● 多级缓存适合哪些业务场景&#xff1f; 缓存思想 空间换时间(索引&#xff0c;集群&a…

Jenkins+gitee 搭建自动化部署

Jenkinsgitee 搭建自动化部署 环境说明&#xff1a; 软件版本备注CentOS8.5.2111JDK1.8.0_211Maven3.8.8git2.27.0Jenkins2.319最好选稳定版本&#xff0c;不然安装插件有点麻烦 一、安装Jenkins程序 1、到官网下载相应的版本war或者直接使用yum安装 Jenkins官网下载 直接…

Docker 存储管理:卷、绑定挂载、临时存储

Docker 提供了多种存储方式&#xff0c;用于容器中的数据存储。根据不同的使用场景&#xff0c;Docker 提供了 卷&#xff08;Volumes&#xff09;、绑定挂载&#xff08;Bind Mounts&#xff09; 和 临时存储&#xff08;Tmpfs&#xff09; 等存储方式。每种存储方式有不同的特…