LeetCode 7题:整数翻转(原创)

【题目描述】

【原题链接】. - 力扣(LeetCode)

给你一个 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

【解题代码】

java 复制代码
package number;

import java.util.ArrayList;
import java.util.List;

public class Reverse {

    public static void main(String[] args) {
        int x = 15340;
        System.out.println(reverse(x));
    }

    private static int reverse(int x) {
        if (x < -Integer.MAX_VALUE || x > Integer.MAX_VALUE) return 0;

        int m = x;
        int n;
        List<Integer> reverseNumbers = new ArrayList<>();
        while (m != 0) {
            n = m - (m / 10) * 10;
            if (reverseNumbers.size() > 0 || n != 0) {
                reverseNumbers.add(n);
            }
            m = m / 10;
        }

        long  i = 1;
        long result = 0;
        long tmp ;
        for (int j = reverseNumbers.size() - 1; j >= 0; j--) {
            tmp = i * reverseNumbers.get(j);
            result += tmp;
            if (result < -Integer.MAX_VALUE || result > Integer.MAX_VALUE) return 0;
            i *= 10;
        }
        return (int)result;
    }

}

【解题思路】

这道题我这次采用最简单的思路,就是通过反复除以10以及乘以10,依次取整数最后的数值,加到链表中,然后将链表中的数字依次取出乘以10相加

【解题步骤】

  1. 定义临时变量m,初始值为输入整数,当前数值m尾数字,存放所有数字的链表等变量;

    java 复制代码
    int m = x;
    int n;
    List<Integer> reverseNumbers = new ArrayList<>();
  2. 当m>0,不断对m取尾部数值,并放入链表中,并将m不断除以10

    java 复制代码
    while (m != 0) {
        n = m - (m / 10) * 10;
        if (reverseNumbers.size() > 0 || n != 0) {
            reverseNumbers.add(n);
        }
        m = m / 10;
    }
  3. 将链表中数字依次倒序取出,并不断乘10相加

    java 复制代码
    for (int j = reverseNumbers.size() - 1; j >= 0; j--) {
        tmp = i * reverseNumbers.get(j);
        result += tmp;
        if (result < -Integer.MAX_VALUE || result > Integer.MAX_VALUE) return 0;
        i *= 10;
    }
  4. 最后返回计算结果

    java 复制代码
    return (int)result;

【思考总结】

  1. 这道题解法比较简单,就是按十进制左右移位计算当前数据尾数值,并通过不断除以10,来获取整数所有数值;
  2. 稍微需要注意一点就是,整数最后连续的0也就是翻转过来的最高位是0的数字丢弃掉:
  3. LeetCode解题之前,一定不要看题解,看了就"破功"了!
相关推荐
我是哈哈hh1 小时前
专题十_穷举vs暴搜vs深搜vs回溯vs剪枝_二叉树的深度优先搜索_算法专题详细总结
服务器·数据结构·c++·算法·机器学习·深度优先·剪枝
Tisfy1 小时前
LeetCode 2187.完成旅途的最少时间:二分查找
算法·leetcode·二分查找·题解·二分
Mephisto.java2 小时前
【力扣 | SQL题 | 每日四题】力扣2082, 2084, 2072, 2112, 180
sql·算法·leetcode
robin_suli2 小时前
滑动窗口->dd爱框框
算法
丶Darling.2 小时前
LeetCode Hot100 | Day1 | 二叉树:二叉树的直径
数据结构·c++·学习·算法·leetcode·二叉树
labuladuo5202 小时前
Codeforces Round 977 (Div. 2) C2 Adjust The Presentation (Hard Version)(思维,set)
数据结构·c++·算法
jiyisuifeng19912 小时前
代码随想录训练营第54天|单调栈+双指针
数据结构·算法
꧁༺❀氯ྀൢ躅ྀൢ❀༻꧂2 小时前
实验4 循环结构
c语言·算法·基础题
新晓·故知3 小时前
<基于递归实现线索二叉树的构造及遍历算法探讨>
数据结构·经验分享·笔记·算法·链表
总裁余(余登武)3 小时前
算法竞赛(Python)-万变中的不变“随机算法”
开发语言·python·算法