LeetCode集锦(二) - reverse integer

栏目: 编程工具 · 发布时间: 6年前

内容简介:给定一个32位带符号整数,对其进行反数运算。示例1:输入:123 输出:321
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. 


复制代码

翻译:

给定一个32位带符号整数,对其进行反数运算。

示例1:

输入:123 输出:321

示例2:

输入:-123 输出:-321

示例3:

输入:120 输出:21

注意: 假设我们处理的环境只能存储32位带符号整数范围内的整数:[- 231,231 - 1]。对于这个问题,假设函数在反向整数溢出时返回0。

解题思路

本题字面含义其实是对一个整数进行反转,这边需要注意三个点:

  1. 带符号
  2. 32位数字,反转后可能会溢出
  3. 翻转后开头为0的要去掉。

思路一:我们可以利用String来进行直接的反转,对目标数先取绝对值,然后翻转,然后去掉头部为0的数字,并且反转完后把符号带上,如果大于Integer,则返回0,这边可以用long来代替,或者在转化integer的时候进行异常捕获

思路二:直接进行数字的翻转,先取绝对值,一个个位数获取下来,然后在拼接为最终结果,并除去头部为0的值,最后赋予富豪,用long来代替,比较integer的最大值。

解题方法

  1. 第一种解体方法,按照我们的思路来编辑,代码如下

    //首先把0特殊去掉
        if (x == 0) {
            return 0;
        }
        //如果是负数,则变化成正数
        int temp = x;
        boolean isMinus = false;
        if (x < 0) {
            temp = -temp;
            isMinus = true;
        }
        //翻转,
        StringBuilder stringBuilder = new StringBuilder(temp+"").reverse();
        //除去前面的0
        int zoreCount = 0;
        for (int i = 0; i < stringBuilder.length(); i++) {
            if (stringBuilder.charAt(i) == '0') {
                zoreCount++;
            } else {
                break;
    
            }
        }
        if(zoreCount>0){
            stringBuilder.delete(0,zoreCount);
        }
        try{
            return Integer.valueOf(isMinus?"-"+stringBuilder.toString():stringBuilder.toString());
        }catch (Exception e){
            return 0;
        }
    复制代码

    时间复杂度: 该方案用了并没有使用循环,其实在翻转过程中应该是用来循环,但是这边不计算,这边在判断头部为0的情况下,循环来一次,所以记为n,所以f(n)=((log10(n)-1)+0)/2=log10(n)/2;所以O(f(n))=O(log10(n)),即T(log10(n))=O(n)

    空间复杂度: 该方案使用了StringBuilder,相当于复刻了一个数组,所以空间复杂度是O(1);

  2. 第二种解题方法,代码如下:

    //如果是负数,则变化成正数
        long temp = x;
        boolean isMinus = false;
        if (x < 0) {
            temp = -temp;
            isMinus = true;
        }
        long value = 0;
        //获取长度。
        while (temp / 10 != 0 || temp % 10 != 0) {
            long remainder = temp % 10;
    
            value = value * 10 + remainder;
            if (value > Integer.MAX_VALUE) {
                return 0;
            }
    
            temp = temp / 10;
        }
    
        return (int) value * (isMinus ? -1 : 1);
    复制代码

    时间复杂度: 该方案用了单层循环,所以f(n)=(log10(n)+1)/2=log10(n)/2;所以O(f(n))=O(log10(n))=O(log10(n)),即T(n)=O(log10(n))

    空间复杂度: 该方案并没有使用额外的空间在存储数值,所以为O(1);

总结

本题的大致解法如上所诉,方案2没有利用到字符串,直接由本身出发,空间和时间上都比方案一快,唯一一点是需要用long来控制,万一int是负数最小值,一旦变成正数,就溢出了。


以上所述就是小编给大家介绍的《LeetCode集锦(二) - reverse integer》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

艾伦•图灵传

艾伦•图灵传

(英)安德鲁·霍奇斯 / 孙天齐 / 湖南科学技术出版社 / 2012-8-1 / 68.00元

《艾伦·图灵传:如谜的解谜者》是图灵诞辰100周年纪念版,印制工艺更为精美。本书是世界共认的最权威的图灵传记。艾伦?图灵是现代人工智能的鼻祖,在24岁时奠定了计算机的理论基础。二战期间,他为盟军破译密码,为结束战争做出巨大贡献。战后,他开创性地提出人工智能的概念,并做了大量的前期工作。因同性恋问题事发,被迫注射激素,后来吃毒苹果而死。作者是一名数学家,也是一名同性恋者。他对图灵的生平有切身的体会,......一起来看看 《艾伦•图灵传》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具