LeetCode:整数反转

LeetCode第7号问题:整数反转

题目描述

给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。

示例:

输入: 123
输出: 321

输入: -123
输出: -321

输入: 120
输出: 21

注意:
假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231, 231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。

解法(java)

每次弹出数字'x'最后一位,并压入到'res'的后面,全部压入后,'x'与'res'即完全相反;

在不使用数据结构的情况下可以借助数学方法来实现“弹出/压入”的操作:

// 弹出
pop = x % 10
x /= 10

// 压入
temp = y * 10 + pop
y = temp 

此方式有溢出风险,使用时应注意每次反转后是否溢出。

反转后数字的溢出情况可以使用Integer.MAX_VALUE和Integer.MIN_VALUE来实现

参考代码:

class Solution {
    public int reverse(int x) {
        long res = 0;
        while(x != 0) {
            res = res * 10 + x % 10;
            x /= 10;
        }
        return res > Integer.MAX_VALUE || res < Integer.MIN_VALUE ? 0 : (int)res;
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 题目 作者:gpe3DBjDS1链接:https://leetcode-cn.com/problems/rever...
    简书帅气的昵称已被使用阅读 260评论 0 0
  • 给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。 示例 1: 示例 2: 示例 3: 注意...
    8239e604d437阅读 293评论 0 0
  • 给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。 示例 1: 输入: 123输出: 321...
    仁安天下阅读 74评论 0 0
  • 在最讨厌的天气最糟糕的模样出门还有那令人窒息的空气里 人与人之间的相遇 就像在地上看见五毛钱一块钱几块钱犹豫着要不...
    吃香菜阅读 203评论 0 6
  • 看到有人说,“我狮子座前男友又变成了我现男友” 巧了,曾经这个事情也发生在我身上。 公众号决定把十二星座凑齐,所以...
    棠宋阅读 17,716评论 12 7