將一個整數中的數字進行顛倒,當顛倒後的整數溢出時,返回 0 (標記爲 32 位整數)。
樣例
給定 x = 123
,返回 321
給定 x = -123
,返回 -321
package com.ak.demo;
import java.util.Scanner;
/**
*
* @ClassName: ReverseInteger
* @Description:
* @author ak
* @date 2015年10月25日 下午10:38:58
*
*/
public class ReverseInteger {
public static void main(String[] args) {
Scanner sacn = new Scanner(System.in);
System.out.println("請輸入一個整數:");
int value = sacn.nextInt();
int reverseValue = reverseInteger(value);
System.out.println("轉換後的值得:"+ reverseValue);
System.out.println("最大值:" + Integer.MAX_VALUE);
System.out.println("最小值:" + Integer.MIN_VALUE);
}
public static int reverseInteger(int n) {
String str = n + "";
System.out.println("傳遞過來的值:" + str);
if(str.contains("-")){
str = str.substring(1, str.length());
System.out.println("負數切割後:" + str);
}
char[] ch = str.toCharArray();
System.out.println("字符長度" + ch.length);
StringBuilder sb = new StringBuilder();
for(int i = ch.length-1; i>=0 ;i--){
sb.append(ch[i]);
}
if(Long.parseLong(sb.toString()) > Integer.MAX_VALUE){
return 0;
}else{
if((n+"").contains("-")){
return - Integer.parseInt(sb.toString());
}
return Integer.parseInt(sb.toString());
}
}
}
由於能力有限,代碼寫的不好,希望看到小夥伴們多多提意見,讓我學習學習。