【Python 千题 —— 算法篇】数字反转

news2024/12/23 0:13:33

请添加图片描述

Python 千题持续更新中 ……
脑图地址 👉:⭐https://twilight-fanyi.gitee.io/mind-map/Python千题.html⭐

字符串处理

题目背景

整数反转是一个经典的算法问题,常见于各种编程竞赛和技术面试中。它要求我们将给定的整数按位进行翻转,并返回反转后的结果。这道题目看似简单,但如果不注意边界条件和数据溢出问题,很容易出现错误。掌握整数反转的算法不仅能提高我们对数字操作的理解,还能帮助我们更好地应对实际开发中的问题。

题目描述

给定一个 32 位的有符号整数 x,将整数 x 中的数字进行反转,并返回反转后的结果。如果反转后整数超过 32 位有符号整数的范围,则返回 0。

输入描述

  • 一个 32 位的有符号整数 x

输出描述

  • 一个整数,表示反转后的结果,如果溢出则返回 0。

示例

示例 ①

输入:

# 调用 reverse() 函数
print(reverse(123))

输出:

321
示例 ②

输入:

print(reverse(-123))

输出:

-321
示例 ③

输入:

print(reverse(120))

输出:

21

代码讲解与多种解法

解法一:字符串反转

最直观的思路是将整数转换为字符串,然后对字符串进行反转,最后再将反转后的字符串转换回整数。这种方法实现简单,但需要注意处理符号和数据溢出。

def reverse(x):
    sign = -1 if x < 0 else 1
    x = abs(x)
    reversed_x = int(str(x)[::-1]) * sign
    
    if reversed_x < -2**31 or reversed_x > 2**31 - 1:
        return 0
    return reversed_x

优点:

  • 实现简单,易于理解和调试。
  • 适合快速解决问题的小型程序。

缺点:

  • 需要使用字符串转换,导致性能较低。
  • 对于大规模数据处理效率不高。

解法二:数学方法

更高效的方式是直接通过数学运算对整数进行反转,不借助字符串转换。这种方法通过逐位提取和重组数字来完成反转,同时可以直接在过程中检查溢出情况。

def reverse(x):
    reversed_x = 0
    sign = -1 if x < 0 else 1
    x = abs(x)
    
    while x != 0:
        pop = x % 10
        x //= 10
        if reversed_x > (2**31 - 1) // 10 or (reversed_x == (2**31 - 1) // 10 and pop > 7):
            return 0
        if reversed_x < -2**31 // 10 or (reversed_x == -2**31 // 10 and pop < -8):
            return 0
        reversed_x = reversed_x * 10 + pop
    
    return sign * reversed_x

优点:

  • 不依赖字符串操作,性能更高。
  • 直接处理数字,代码更加紧凑高效。

缺点:

  • 实现稍微复杂,需要仔细处理边界和溢出情况。
  • 对初学者理解有一定挑战。

解法三:递归反转

我们还可以通过递归来实现整数反转。这种方法通过逐位递归地反转数字,并在递归过程中逐步重组反转后的整数。

def reverse(x, rev=0):
    if x == 0:
        return rev
    pop = x % 10
    x //= 10
    rev = rev * 10 + pop
    if rev > 2**31 - 1 or rev < -2**31:
        return 0
    return reverse(x, rev)

优点:

  • 代码简洁优美,体现递归思想。
  • 适合理解递归和数学运算的结合。

缺点:

  • 递归深度可能导致栈溢出,处理大数字时需要小心。
  • 递归方法的效率通常不如迭代方法。

总结与思考

整数反转问题可以通过多种方式解决,包括字符串反转、数学方法和递归反转等。每种方法都有其优缺点,选择合适的方法取决于具体应用场景和对性能的要求。

  1. 字符串反转:适合处理简单情况,易于理解和实现,但性能较低。
  2. 数学方法:直接操作数字,性能较高,适合处理大规模数据,但实现复杂。
  3. 递归反转:代码简洁优美,但需要注意递归深度和性能。

扩展思考

  1. 溢出处理:在实际应用中,我们不仅要考虑算法本身,还需要注意溢出情况的处理,特别是在处理大整数或特殊硬件平台时。
  2. 其他数字操作:类似整数反转的算法还有很多,如判断回文数、数字的重新排列等。掌握这些基本算法可以为更复杂的数字操作奠定基础。
  3. 优化算法:通过优化算法或引入并行计算,可以进一步提高整数反转的效率,特别是在处理大量数据时。

通过本文的讲解,你不仅掌握了整数反转的基本算法,还学会了如何分析和优化数字处理问题。希望这能为你今后的编程之路带来帮助和启发。

关注博客,解锁更多字符串处理技巧!
作者信息

作者 : 繁依Fanyi
CSDN: https://techfanyi.blog.csdn.net
掘金:https://juejin.cn/user/4154386571867191

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2116920.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

c++ string类的模拟实现的注意事项

一.构造函数 第一种形式&#xff0c;使用字符指针赋值 为了防止修改&#xff0c;我们传入了常量字符串。但是这里的初始化列表出错了&#xff0c;因为_str是一个变量&#xff0c;将常量给到一个变量涉及到权限的放大&#xff0c;是错误的。那该怎么写呢&#xff1f;对_str的赋…

证书学习(四)X.509数字证书整理

目录 一、X.509证书 介绍1.1 什么是 X.509证书?1.2 什么是 X.509标准?1.3 什么是 PKI?二、X.509证书 工作原理2.1 PKI 的基础——加密算法2.2 PKI 证书编码三、X.509证书 结构3.1 证书字段3.2 证书扩展背景: 我们在日常的开发过程中,经常会遇到各种各样的电子证书文件,其…

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点&#xff08;链表、模拟&#xff09; 题目描述 给定一个链表&#xff0c;链表中的每个节点代表一个整数。链表中的整数由 0 分隔开&#xff0c;表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所…

虚拟机VMware桥接网络命令来重置 /etc/sysconfig/network-scripts/ifcfg-ens33 文件

ifcfg-ens33 文件专门用于配置这个特定的网络接口。 有时候把ifcfg-ens33文件配置弄乱了&#xff0c;可以使用命令重置。 最常用的方式是通过 nmcli 或者 nmtui 来重置网络接口的配置。 第一种方法. 使用 nmcli 命令重置网络配置 nmcli 是一个强大的网络管理命令行工具&…

闯关leetcode——3.Longest Substring Without Repeating Characters

大纲 题目地址内容 解题代码地址 题目 地址 https://leetcode.com/problems/longest-substring-without-repeating-characters/description/ 内容 Given a string s, find the length of the longest substring without repeating characters. Example 1: Input: s “abc…

力扣最热一百题——矩阵置零

目录 题目链接&#xff1a;73. 矩阵置零 - 力扣&#xff08;LeetCode&#xff09; 题目描述 示例 提示&#xff1a; 解法一&#xff1a;采用标记数组遍历处理 Java写法&#xff1a; C写法&#xff1a; 优化 解法二&#xff1a;优化解法之标记变量 Java写法&#xff1a;…

【鸿蒙HarmonyOS NEXT】UIAbility的生命周期

【鸿蒙HarmonyOS NEXT】UIAbility的生命周期 一、环境说明二、UIAbility的生命周期三、示例代码加以说明四、小结 一、环境说明 DevEco Studio 版本&#xff1a; API版本&#xff1a;以12为主 二、UIAbility的生命周期 概念&#xff1a; HarmonyOS中的UIAbility是一种包含…

入门pytorch

卷积神经网络模型 卷积神经网络&#xff08;简称 CNN&#xff09;是一种专为图像输入而设计的网络。它最明显的特征就是具有三个层次&#xff0c;卷积层&#xff0c;池化层&#xff0c;全连接层。 借用一张图&#xff0c;下图很好的表示了什么是卷积&#xff08;提取特征&…

机器学习:多种算法处理填充后的数据

在机器学习中&#xff0c;填充数据&#xff08;即处理缺失值&#xff09;后&#xff0c;选择合适的算法并优化模型以提高召回率是一个常见的任务。召回率是指模型正确识别的正例占所有实际正例的比例。 代码思路&#xff1a; 数据预处理&#xff1a; 导入填充后的数据 …

FastGPT自定义插件的icon

最近研究FastGPT的自定义插件&#xff0c;经过好几天的折磨&#xff0c;终于实现了一个简单的发送邮件功能&#xff0c;但是呢在使用的时候发现插件的icon是默认的fastgpt的logo&#xff0c;那肯定得自定义一个啊。直接说方法&#xff1a; 1、自定义插件下面的template.json文件…

zookeeper相关面试题

zk的数据同步原理&#xff1f;zk的集群会出现脑裂的问题吗&#xff1f;zk的watch机制实现原理&#xff1f;zk是如何保证一致性的&#xff1f;zk的快速选举leader原理&#xff1f;zk的典型应用场景zk中一个客户端修改了数据之后&#xff0c;其他客户端能够马上获取到最新的数据吗…

握 手 问 题

目录 一&#xff1a;问题描述 二&#xff1a;思路: 三&#xff1a;代码&#xff1a; 四&#xff1a;结果&#xff1a;1204 一&#xff1a;问题描述 小蓝组织了一场算法交流会议&#xff0c;总共有50 5050 人参加了本次会议。在会议上&#xff0c;大家进行了握手交流。按照…

excel如何删除某列或者某区域的重复数据

先&#xff0c;鼠标选中想要去除重复数据的某列或者某区域 然后&#xff0c;点击上方栏中的【数据】-【删除重复数据】&#xff1a; 之后&#xff0c;表格里只留下了无重复的数据

STM32(十一):ADC数模转换器实验

AD单通道&#xff1a; 1.RCC开启GPIO和ADC时钟。配置ADCCLK分频器。 2.配置GPIO&#xff0c;把GPIO配置成模拟输入的模式。 3.配置多路开关&#xff0c;把左面通道接入到右面规则组列表里。 4.配置ADC转换器&#xff0c; 包括AD转换器和AD数据寄存器。单次转换&#xff0c;连…

Kafka (快速)安装部署

文章目录 1、软件下载&配置环境1_JDK安装2_Zookeeper安装3_Kafka安装 2、单机安装1_配置主机名和IP映射2_单机Kafka配置 3、集群安装1_配置主机名和IP的映射关系2_时钟同步3_Zookeeper配置信息4_集群Kafka配置 4、kafka的其他脚本命令5、监控工具Kafka-eagle安装 1、软件下…

Java并发编程实战 07 | 如何正确停止线程

什么时候需要停止一个线程&#xff1f; 一个线程被创建并启动之后&#xff0c;大部分情况下都会自然运行至结束&#xff0c;但是也有一些情况需要主动停止线程&#xff0c;比如&#xff1a; 用户主动取消执行&#xff1a;用户可能会中止一个正在进行的操作&#xff0c;这时需…

Python系统教程004(字符串)

一、input函数的算术运算 一包奥特曼卡片卖0.5元&#xff0c;小华想编写一个只需要输入卡片的包数就能自动计算价格的程序&#xff0c;请你帮帮它。 解题 报出类型错误 注意&#xff1a; input函数接收到的键盘信息&#xff0c;默认都是字符串的数据类型。 字符串的数据类型…

书生浦语三期实战营 [进阶] LMDeploy 量化部署进阶实践

LMDeploy 量化部署进阶实践 1 配置LMDeploy环境 1.1 InternStudio开发机创建与环境搭建 在终端中&#xff0c;让我们输入以下指令&#xff0c;来创建一个名为lmdeploy的conda环境&#xff0c;python版本为3.10&#xff0c;创建成功后激活环境并安装0.5.3版本的lmdeploy及相关…

IM即时通讯,稳定可靠的即时通讯服务-WorkPlus

在现代企业日常工作中&#xff0c;即时通讯已成为了一种不可或缺的沟通工具。为了满足企业对稳定可靠的即时通讯服务的需求&#xff0c;WorkPlus提供了一款优秀的IM即时通讯平台&#xff0c;以满足企业高效沟通和协作的要求。本文将深入探讨IM即时通讯服务的重要性以及WorkPlus…

Linux下的RTC应用

RTC RTC基础知识 1. RTC简介 RTC 全称是 Real-Time clock&#xff0c;翻译过来是实时时钟。实时时钟在日常生活中的应用也比较泛&#xff0c;比如电子时钟。实时时钟可以为系统提供精确的实时时间&#xff0c;通常带有电池&#xff0c;可以保证系统断电时还可以正常工作&…