LeetCode-7-算法- 整数反转(简单)

给出一个 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;
	}

 

你可能感兴趣的:(语言,算法)