关于将输入字符串转换为整型,下面是要求以及实现。
- 将字符串"123 694 234"去重并顺序排序;
- 在控制台输入文字,转换为整型(不能转换的做处理)不能包含try catch,不能出现异常。
逻辑代码如下:
package com.test.string;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;
import java.util.regex.Pattern;
public class TestDemo {
//1,将123 694 234去重并顺序排序;
private static int Sort(String str){
char[] c = str.replaceAll(" ", "").toCharArray();
StringBuilder sb = new StringBuilder();
Map<String, Object> m = new HashMap<String, Object>();
for (int i = 0; i < c.length; i++) {
m.put(c[i]+"", c[i]);
}
Object[] o = m.keySet().toArray();
Arrays.sort(o);
for (int i = 0; i < o.length; i++) {
sb.append(o[i]);
}
return Integer.parseInt(sb.toString());
}
@SuppressWarnings("resource")
public static void main(String[] args) {
//1
System.out.println("去重排序结果:"+Sort("123 694 234"));
//2,将控制台输入的文字转换为整形输出,不能使用try catch 不能出现转换异常;
Pattern p = Pattern.compile("-?\\d+");
while (true) {
System.out.println("请输入:");
String str = new Scanner(System.in).next();
if (str == null) {
System.err.println("输入为null,请重新输入");
continue;
}else {
str.replaceAll(" ","");
if ("".equals(str.trim())) {
System.err.println("输入为空格,请重新输入");
continue;
}else {
if (!p.matcher(str).matches()){
System.err.println("包含非数字字符,请重新输入");
continue;
}else {
Double l = Double.parseDouble(str);
if(l.doubleValue()>=Integer.MIN_VALUE&&l.doubleValue()<Integer.MAX_VALUE) {
System.out.println("Integer 范围:< " +Integer.MIN_VALUE+","+Integer.MAX_VALUE+" >");
System.out.println("数字转换为INTEGER型,输入值为:"+Integer.parseInt(str));
}else if (l.doubleValue()>=Long.MIN_VALUE&&l.doubleValue()<=Long.MAX_VALUE) {
System.out.println("Long 范围:< " +Long.MIN_VALUE+","+Long.MAX_VALUE+" >");
System.out.println("数字转换为LONG型,输入值为:"+Long.parseLong(str));
}
else{
System.out.println("Double 范围:< " +Double.MIN_VALUE+","+Double.MAX_VALUE+" >");
System.out.println("输入数字过长,不能转换为整型,输入值为:"+l.doubleValue());
}
}
}
}
}
}
}
当输入数字超出(Double.MIN_VALUE,Double.MAX_VALUE),返回(-)infinity:(负)无穷大。
虽然很简单,但很容易出错,记录一下,如有不对,欢迎批评指正。
本文介绍如何将控制台输入的字符串转换为整型,并处理输入的特殊情况。内容包括将带有空格的字符串去重排序,以及在不使用try-catch的情况下避免转换异常。当数字超出Double的最小和最大值时,返回负无穷大。
420

被折叠的 条评论
为什么被折叠?



