//Scanner를 사용했을시 입력 형태.
Scanner sc = new Scanner(System.in);
int n = sc.nextInt(); // int
long l = sc.nextLong(); // int
String s = sc.next(); // String
String s = sc.nextLine(); // String
// 1 2 3 4 5 6 7 8 9 10 11 12 // 한줄 입력
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String[] s = br.readLine().split(" "); // 문자열로 받고 split메소드를 이용해서 공백을 기준으로 잘라서 활용.
// s[0] = "1"; Integer.parseInt(s[0]) => 1
// s[1] = "2";
// s[2] = "3";
// .....
split VS StringTokenizer의 nextToken
StringTokenizer는 공백이 있다면 뒤에 문자열이 공백 자리를 당겨 채우도록 한다.
StringTokenizer가 BufferedReader보다 빠르게 사용될 수 있다.
문자열을 자르게 위해 split을 사용할 땐, split은 정규식을 기반으로 자르는 로직으로서 내부는 복잡하다. 그에 비해 StringTokenizer의 nextToken() 메서드는 단순히 공백 자리를 당겨 채우는 것이다.정규식 처리가 딱히 필요한 게 아닌 경우 StringTokenizer가 효율적이다.
정규식이나 인덱스 접근과 같은 처리가 필요 없다면 StringTokenizer를 사용하는 것이 효율적이다.
StringTokenizer 사용법
자바에서는 String을 token단위로 끊어주는 StringTokenizer 클래스를 제공한다.
예를 들어 “this is my string”이라는 스트링을 this, is, my, string 4개의 스트링으로 끊어주는 기능을 제공한다.
그리고 공백 말고도 다른 구획문자(delimiter)를 사용할 수도 있다. 예를 들어 this% is% my% string을 delimiter에 %를 넣어 StringTokenizer를 사용하면 마찬가지로 this, is, my, string으로 읽어준다.
thismy% string^일 때 구획문자를 “$%^”라고 설정해 주면 this, is, my, string으로 끊어준다.
BufferedReader br = new BufferedReader(new InputStreamReader(System.in);
StringTokenizer st = new StringTokenizer(br.readLine());
// AB CDD EFFF GH 입력
st.nextToken() // AB
st.nextToken() // CDD
st.nextToken() // EFFF
st.nextToken() // GH
String str = "this%%is%%my%%string";
StringTokenizer st = new StringTokenizer(str,"%%");
while(st.hasMoreTokens()) {
System.out.println(st.nextToken());
}