| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> Leetcode7: 整数翻转(medium) -> 正文阅读 |
|
[数据结构与算法]Leetcode7: 整数翻转(medium) |
目录 1. 题目描述
示例 2:输入:x = -123;输出:-321 示例 3:输入:x = 120;输出:21 示例 4:输入:x = 0;输出:0 来源:力扣(LeetCode) 2. 解题分析????????考察要点:整型数、字符串、列表之间的相互转换 ????????容易忽视的坑及边界情况处理:
以下考虑两种实现方式。 3. 代码实现3.1 实现1????????利用字符串处理技术来解决。 ? ? ? ? 将整数先变成字符串表达形式,然后将除‘-’号(如果有的话)以外的部分进行字符串逆序处理,然后再变回整数。python中字符串逆序处理的可以很简洁用s[::,-1]来实现。
? 3.2 实现2????????直接进行整型数的变换,对绝对值进行按数位进行扫描,稍微麻烦一点吧。
????????以上两种解法都利用了python的一些内置高级特性,有点取巧。 ? ? ? ? Python是可以表达超过32比特位宽的整数的,因此进行超过32比特位宽的判断就很直接简单。但是对于像C语言那种本身只能表达32比特的整型数的语言,你不可能进行if(x>2**31-1)之类的判断,这个地方需要一些小技巧。 ? ? ? ? 另外,在解法一中,python的int(numstr)将整数的字符串表现形式变换为整数值时自动将头上的0给剥离掉了。这个在C或其它不具备这种内置处理的语言中也同样需要一些额外的小飞刀。从这个意义上来说,python提供了这么多的内置小飞刀,把用用python编程的人都给惯傻了。。。^-^ 回到本系列总目录:笨牛慢耕的Leetcode解题笔记(动态更新。。。)https://chenxiaoyuan.blog.csdn.net/article/details/123040889 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/10 2:32:44- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |