反转数字(NC57/考察次数Top59/难度简单)

Posted 码农指南

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了反转数字(NC57/考察次数Top59/难度简单)相关的知识,希望对你有一定的参考价值。

描述:
给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。
你有注意到翻转后的整数可能溢出吗?因为给出的是32位整数。翻转可能会导致溢出,如果反转后的结果会溢出就返回 0。

示例1
输入:
12
返回值:
21
(题目来自牛客网)

用C++实现如下

class Solution {
public:
    /**
     *
     * @param x int整型
     * @return int整型
     */
    int reverse(int x) {
        int res = 0;
        while(x != 0)
        {
            res = res*10+x%10;                 //x%10,依次得到 个 十 百 千 万等位数上的值;而 res*10 则等于非个位上的累加值;
            x/=10;                             //此两步可每次记录住最后一位的值,每次剔除掉最后一位的值
            if(res < INT_MIN || res > INT_MAX) //注意超限的异常情况,则需要返回0
                return 0;
        }
        return res;                            //反转数字成功
    }
};

纯手撕代码,如果觉得内容不错麻烦点个赞,后面陆续配上Top100算法题通俗易懂的讲解视频,可以花两个月时间完全掌握,进大厂不是梦,转行狗亲测!

以上是关于反转数字(NC57/考察次数Top59/难度简单)的主要内容,如果未能解决你的问题,请参考以下文章

回文数字(NC56/考察次数Top65/难度简单)

回文数字(NC56/考察次数Top65/难度简单)

反转链表(NC78/考察次数Top1/难度简单)

反转字符串(NC103/考察次数Top26/难度入门)

缺失数字(NC101/考察次数Top60/难度简单)

缺失数字(NC101/考察次数Top60/难度简单)