본문 바로가기
ALGORITHM/백준 With Node.js

[백준] 1152번 / 단어의 개수 / Node.js

by LAY CODER 2021. 4. 26.

문제

 

영어 대소문자와 띄어쓰기만으로 이루어진 문자열이 주어진다. 이 문자열에는 몇 개의 단어가 있을까? 이를 구하는 프로그램을 작성하시오. 단, 한 단어가 여러 번 등장하면 등장한 횟수만큼 모두 세어야 한다.

 

입력

 

첫 줄에 영어 대소문자와 띄어쓰기로 이루어진 문자열이 주어진다. 이 문자열의 길이는 1,000,000을 넘지 않는다. 단어는 띄어쓰기 한 개로 구분되며, 공백이 연속해서 나오는 경우는 없다. 또한 문자열의 앞과 뒤에는 공백이 있을 수도 있다.

 

출력

 

첫째 줄에 단어의 개수를 출력한다.

 

예제 입력 1

 

The Curious Case of Benjamin Button

 

예제 출력 1

 

6

 

예제 입력 2

 

Mazatneunde Wae Teullyeoyo

 

예제 출력 2

 

3

 

예제 입력 3

 

Teullinika Teullyeotzi

 

예제 출력 3

 

2

 

CODE

const readline = require('readline');

const rl = readline.createInterface({
    input: process.stdin,
    output: process.stdout,
});

rl.on('line', function (line) {
    // 입력받은 문자의 양 끝의 공백을 제거한 후 공백을 기준으로 split
    let words = line.trim().split(' ');

    // // 배열 요소 중 ''를 걸러냄.
    // words = words.filter((e) => e !== '');

    // 문제에서 공백이 연속해서 나오는 경우가 없다고 했으니 filter 안 써도 됨
    if (words[0] === '') {
        console.log(0);
    } else {
        console.log(words.length);
    }

    rl.close();
}).on('close', function () {
    process.exit();
});

 

 

Comment

 

어려운 문제는 아니지만 두 가지 점에 대해서 유의해야한다.

 

입력 문자열의 앞과 뒤에 공백이 있을 수 있기에 String.trim()을 이용하여 입력받은 문자열의 양 끝 공백을 제거한다.

 

또 입력받은 문자가 ' ' 일 경우에는  split(' ') 하는 과정에서 words배열에 ''가 추가되기 때문에

 

words[0]이 '' 일 경우의 조건을 마지막에 삽입해야 한다.

 

이 부분 때문에 쉬워 보이지만 정답률이 적은 문제이다.

 

댓글