LeetCode7-ReverseInteger

LeetCode7-ReverseInteger

题目

题目所在链接为 LeetCode-7:ReverseInteger

题目描述

给出一个32位的有符号整数, 反向输出一个整型数字

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

备注

假设我们正在处理一个只能在32位有符号整数范围内存储整数的环境:[−231, 231 − 1]。出于此问题的目的,假设当反向整数溢出时,函数返回0.

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.

例如 $2^{31} -1 = 2,147,483,647$ 如果 设计的返回的值应该是$ 7,463,847,412 $ 溢出 返回0 .

解题

解题思路

  1. 通过余数和除法获取 从尾部 获取数据的每一位,依次成将数据乘10 得到新的数据
  2. 判断符号, 判断是否溢出

时间复杂度: $ O(log(x)) $
空间复杂度: $ O(1) $

具体实现

class Solution {
public:
    int reverse(int x) {
        if (x == 0)
            return 0;
        // 输入long long 型 数据 避免溢出
        long long sum = 0;
        while (x!=0)
        {
            // 将每一位的数据 升位 加上余数
            sum = sum * 10 + x % 10;
            
            // 输入数字 降位
            x = x / 10;
            
            // 判断溢出
            if (sum > INT_MAX || sum < INT_MIN)
                return 0;
        }
        return int(sum);
    }
};

运行结果

使用C/C++实现
运行结果 2019-03-27

Runtime: 8 ms, faster than 99.38% of C++ online submissions for Reverse Integer.
Memory Usage: 8.2 MB, less than 99.80% of C++ online submissions for Reverse Integer.

改进优化

改进思路

题目底下最好的优化在了空间上的节省, 不用设置 long long 类型的数据, 采用int 型数据, 但是每次判断依次结果
很多数据会导致溢出 直接抛弃掉 可以节省大量的时间

整体流程如下:

  1. 如果结果会溢出, 如果是正值 则 $temp = rev*10+pop $ 则
    $$ rev > frac{INTMAX}{10} || (rev == frac{INTMAX}{10} && pop>7) $$

  2. 如果结果会溢出, 如果是负值 则 $temp = rev*10+pop $ 则
    $$ rev <> frac{INTMIN}{10} || (rev == frac{INTMIN}{10} && pop<-8) $$

  3. 其中 $ pop = x%10 $

改进的实现

class Solution {
public:
   int reverse(int x) {
       int rev = 0;
       while (x != 0) {
           int pop = x % 10;
           x /= 10;
           if (rev > INT_MAX/10 || (rev == INT_MAX / 10 && pop > 7)) return 0;
           if (rev < INT_MIN/10 || (rev == INT_MIN / 10 && pop < -8)) return 0;
           rev = rev * 10 + pop;
       }
       return rev;
   }
};

运行结果

Runtime: 4 ms, faster than 100.00% of C++ online submissions for Reverse Integer.
Memory Usage: 8.1 MB, less than 99.80% of C++ online submissions for Reverse Integer.

原文地址:https://www.cnblogs.com/hugochen1024/p/12570716.html