力扣整数反转 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)