java Split 实现去除一个空格和多个空格
用Split函数可以去除输入一个字符串中的空格,并且一般都是将它存储在一个字符串数组之中
例如:
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner in = new Scanner(System.in); String s=in.nextLine(); //如果我输入:0 1 2 3 4 String[] str=s.split(" "); System.out.println(s); System.out.println(str[3]); } }
输出结果是:
0 1 2 3 4
3
可是会出现这种情况,如果我输入的是0 1 2 3 4,在2和3之间有3个的空格,那还会有用吗?
结果输出是:
0 1 2 (空格) 3 4
(空格)
也就是没有输出str[3],至少看上去是这样的,然后我分析得出结论,其实是这样的,
举个例子,我输入2(空)(空)(空)3,执行Split函数后得到的String str数组
是str[0]=2 ,str[1]=(空),str[2]=(空),str[3]=3
也就是说,Split函数在执行多空格判断时,会只将第一个空格忽略,其余空格都放入数组,直到遇到非空格数3,然后后面的情况重复,只有一个空格,情况是结果是理想的,多个空格,又是重复如此
解决方法:
import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner in = new Scanner(System.in); String s=in.nextLine(); String[] str=s.split("\\s+ "); //改动这里 System.out.println(s); System.out.println(str[3]); } }
利用正则表达式,就可以实现我们理想的结果,
例如:输入2(空)(空)(空)3
结果:
str[0]=2
str[1]=3
补充知识:Java 键盘输入数字(空格隔开) 将数字存入数组
Scanner方法
核心是单行输入字符串,切割字符串中的空格,存入数组
Scanner s = new Scanner(System.in); String inputStr = s.nextLine(); String[] strArray = inputStr.split(" "); int[] num = new int[strArray.length]; for(int i = 0 ; i < num.length ; i++){ num[i] = Integer.parseInt(strArray[i]); }
Scanner输入的一个问题:在Scanner类中如果我们在任何7个nextXXX()方法之后调用nextLine()方法,这nextLine()方法不能够从控制台读取任何内容,并且,这游标不会进入控制台,它将跳过这一步。nextXXX()方法包括nextInt(),nextFloat(), nextByte(),nextShort(),nextDouble(),nextLong(),next()。此时应该使用BufferedReader。 ?
BufferedReader方法
首行输入数组大小,次行输入数组内容,依次用空格隔开。
它的优势在于消耗比scanner更少的内存和时间,如果在写算法时优先使用BufferedReader方法。
注意:使用完记得close,Scanner方法不需要close。
public static int[] ListInput() throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); int N = 0; String str = null; N= Integer.parseInt(br.readLine()); str = br.readLine(); br.close(); int[] myList = new int[N]; String[] strArray = str.split(" "); for (int i = 0; i < N; i++) { myList[i] = Integer.parseInt(strArray[i]); } return myList; } ···
以上这篇java Split 实现去除一个空格和多个空格就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。