力扣整数反转 JAVA

Posted 蒙面侠1024

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了力扣整数反转 JAVA相关的知识,希望对你有一定的参考价值。

在这里插入图片描述

在这里插入图片描述
题目给出提示,输入数据在int范围内,前面不用加判断,因为反转后数据可能可能爆int,所以在输出之前进行判断是否超过int的数据范围。

题解一:
该题解采用JAVA字符串处理,先将整数转换为字符串,再用StringBuffer里的reverse反转字符串,最后把负号替换。循环除去反转后开头的0,使用Long转换字符串,再强制转换为int,判断未转换之前是否相等,如果不相等就已经爆int了,返回0即可;最后判断x是否大于0,保持数据的正负号。

class Solution {
    public int reverse(int x) {
		 String s=new StringBuffer(Integer.toString(x)).reverse().toString().replace("-", "");
		 for(int i=0;i<s.length();i++) {
			 if (s.charAt(i)!='0') {
				 long tmp=Long.parseLong(s.substring(i));
				 if ((int)tmp!=tmp)
					return 0;
				 return x>0?  (int) tmp:(int) tmp*(-1);
			}
		 }
		 return 0;
	 }
}

题解二:

使用循环来进行反转。

public int reverse(int x) {
        long n = 0;
        while(x != 0) {
            n = n*10 + x%10;
            x = x/10;
        }
        return (int)n==n? (int)n:0;
    }

以上是关于力扣整数反转 JAVA的主要内容,如果未能解决你的问题,请参考以下文章

力扣整数反转 JAVA

力扣整数反转 JAVA

7. 整数反转(leetcode力扣算法 - java / rust)

7. 整数反转(leetcode力扣算法 - java / rust)

LeetCode 力扣7. Reverse Integer 整数反转 Java 解法

LeetCode 力扣7. Reverse Integer 整数反转 Java 解法