leet-code/src/main/java/leetcode/editor/cn/ReverseInteger.java

90 lines
2.0 KiB
Java
Raw Normal View History

2021-05-03 18:11:56 +08:00
//给你一个 32 位的有符号整数 x ,返回将 x 中的数字部分反转后的结果。
//
// 如果反转后整数超过 32 位的有符号整数的范围 [231, 231 1] ,就返回 0。
//假设环境不允许存储 64 位整数(有符号或无符号)。
//
//
//
// 示例 1
//
//
//输入x = 123
//输出321
//
//
// 示例 2
//
//
//输入x = -123
//输出:-321
//
//
// 示例 3
//
//
//输入x = 120
//输出21
//
//
// 示例 4
//
//
//输入x = 0
//输出0
//
//
//
//
// 提示:
//
//
// -231 <= x <= 231 - 1
//
// Related Topics 数学
// 👍 2759 👎 0
package leetcode.editor.cn;
//7:整数反转
public class ReverseInteger {
public static void main(String[] args) {
//测试代码
Solution solution = new ReverseInteger().new Solution();
System.out.println(solution.reverse(123));
System.out.println(solution.reverse(-123));
System.out.println(solution.reverse(120));
System.out.println(solution.reverse(0));
System.out.println(solution.reverse(1534236469));
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public int reverse(int x) {
// boolean is = x < 0;
// if (is) {
// x = -x;
// }
// StringBuilder sb = new StringBuilder(""+x);
// sb.reverse();
// try {
// x = is ? -Integer.parseInt(sb.toString()) : Integer.parseInt(sb.toString());
// }catch (Exception e){
// x = 0;
// }
// return x;
int rev = 0;
while (x != 0) {
if (rev < Integer.MIN_VALUE / 10 || rev > Integer.MAX_VALUE / 10) {
return 0;
}
int digit = x % 10;
x /= 10;
rev = rev * 10 + digit;
}
return rev;
}
}
//leetcode submit region end(Prohibit modification and deletion)
}