给出一个 32 位的有符号整数,你需要将这个整数中每位上的数字进行反转。
示例 1:
输入: 123
输出: 321
示例 2:
输入: -123
输出: -321
示例 3:
输入: 120
输出: 21
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/reverse-integer
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
审题:反转字符串,思考的两种方式有问题,字符串可以使用这两种方式处理。
思考:
最简单的方式是循环遍历,从最大开始--
通过char数组的方式。
解题:
方法一:
方法:弹出和推入数字 & 溢出前进行检查
思路
我们可以一次构建反转整数的一位数字。在这样做的时候,我们可以预先检查向原整数附加另一位数字是否会导致溢出。
算法
反转整数的方法可以与反转字符串进行类比。
我们想重复“弹出” x 的最后一位数字,并将它“推入”到rev 的后面。最后,rev 将与 x 相反。
要在没有辅助堆栈 / 数组的帮助下 “弹出” 和 “推入” 数字,我们可以使用数学方法。
public int reverses(int x) {
int rev = 0;
while (x != 0) {
// 取余数,即最后一位数
int pop = x % 10;
// x等于x整除10,不要余数;将余数那位去掉。
x /= 10;
/*
* 用于判断输入反转后是否会溢出,
*/
if (rev > Integer.MAX_VALUE / 10 || (rev == Integer.MAX_VALUE / 10 && pop > 7))
return 0;
if (rev < Integer.MIN_VALUE / 10 || (rev == Integer.MIN_VALUE / 10 && pop < -8))
return 0;
//将后余数续上,前边需要乘10
rev = rev * 10 + pop;
}
return rev;
}