力扣整数反转 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的主要内容,如果未能解决你的问题,请参考以下文章

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

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

力扣7整数反转

力扣(LeetCode)整数反转 个人题解

7.整数反转Java版,每日一题系列(此题来自力扣网)

7.整数反转Java版,每日一题系列(此题来自力扣网)