LeetCode——Reverse Integer

本文介绍了一种使用Java实现的反转整数的方法,并通过异常处理来确保反转后的整数不会超出int类型的范围。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Reverse Integer


Reverse digits of an integer.

Example1: x = 123, return 321
Example2: x = -123, return -321

public class Solution {
    public int reverse(int x) {
       String tmp = new String();
		String tmp_2 = new String();
		tmp = ((Integer) x).toString();

		if (tmp.charAt(0) == '-') {
			for (int i = tmp.length() - 1; i > 0; i--)
				tmp_2 = tmp_2 + tmp.charAt(i);
			tmp = "-" + tmp_2;
		} else {
			for (int i = tmp.length() - 1; i >= 0; i--)
				tmp_2 = tmp_2 + tmp.charAt(i);
			tmp = tmp_2;
		}

		return Integer.parseInt(tmp);  
    }
}

Submission Result: Runtime Error

Runtime Error Message: Line 17: java.lang.NumberFormatException: For input string: "7463847412"
Last executed input: 2147483647



 

返回结果超出int整数范围,应该考虑转化之后数值大小的边界检查

原先的思路是用穷举法对结果检查,试了很多次都没有pass;一怒之下,直接用try/catch捕捉异常,搞定。

Java代码:

public class Solution {
    public int reverse(int x) {
       String tmp = new String();
		String tmp_2 = new String();
		tmp = ((Integer) x).toString();

		if (tmp.charAt(0) == '-') {
			for (int i = tmp.length() - 1; i > 0; i--)
				tmp_2 = tmp_2 + tmp.charAt(i);
			tmp = "-" + tmp_2;
		} else {
			for (int i = tmp.length() - 1; i >= 0; i--)
				tmp_2 = tmp_2 + tmp.charAt(i);
			tmp = tmp_2;
		}
        try{
			Integer.parseInt(tmp);
		}catch(Exception e){
			return 0;
		}
		return Integer.parseInt(tmp);  
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值