leetcode 7. Reverse Integer(C++)

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: [−23 1 , 23−1] . For the purpose of this problem, assume that your function returns 0 when the reversed integer overflows


题目大意:

  32位有符号int型整数,将它反转。

解题思路:

  思路比较多,主要的问题在于有的转换后会溢出超过int可表示的范围。第一个思路可以转成string再用stoi转换成int型;第二个思路是直接利用除法和余数将每一位的数字分离出来,分离出来的数字乘以10再加上下一个分离出来的数字,直到原来传入的数字变为0。
  P.S.这道题WA了几次,主要是没有注意到int范围,当溢出时要记得返回0.

解题代码:

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;
                        //当x为正数时,如果x比INT_MAX大则返回0
            if (rev < INT_MIN / 10 || (rev == INT_MIN / 10 && pop < -8)) return 0;
                        //当x为负数时,如果x比INT_MIN小则返回0
            rev = rev * 10 + pop;
        }
        return rev;
    }
};

你可能感兴趣的:(leetcode 7. Reverse Integer(C++))