티스토리 뷰

728x90
반응형

목차

     

    문제

     

    예전에는 운영체제에서 크로아티아 알파벳을 입력할 수가 없었다. 

    따라서, 다음과 같이 크로아티아 알파벳을 변경해서 입력했다.

     

    예를 들어, ljes=njak은 크로아티아 알파벳 6개(lj, e, š, nj, a, k)로 이루어져 있다. 

    단어가 주어졌을 때, 몇 개의 크로아티아 알파벳으로 이루어져 있는지 출력한다.

    dž는 무조건 하나의 알파벳으로 쓰이고, d와 ž가 분리된 것으로 보지 않는다. 

    lj와 nj도 마찬가지이다. 위 목록에 없는 알파벳은 한 글자씩 센다.

     

    입력

     

    첫째 줄에 최대 100글자의 단어가 주어진다. 알파벳 소문자와 '-', '='로만 이루어져 있다.

    단어는 크로아티아 알파벳으로 이루어져 있다. 문제 설명의 표에 나와있는 알파벳은 변경된 형태로 입력된다.

     

    출력

     

    입력으로 주어진 단어가 몇 개의 크로아티아 알파벳으로 이루어져 있는지 출력한다.

     

    풀이

     

    여러 가지 방법으로 풀 수 있겠지만, 나는 문자열을 조금 더 고급스럽게 다루는 법을 배우고 싶어서 이 방법을 택했다.

     

    이 방법이란, 주어진 문자열에서 크로아티아 알파벳 입력(c= 등)을 전부 찾아 'A'로 바꾼 뒤

     

    교체가 끝난 문자열의 길이를 출력하는 것이다.

     

    먼저, 자바스크립트에서 문자열에 특정 문자가 들어있는지 확인하는 방법은 다음과 같다.

    let str = "Hello, world!";
    console.log(str.includes("world"));  // true 출력
    console.log(str.includes("c="));     // false 출력

    이어서, 특정 문자열을 다른 문자열로 바꾸는 법은 아래와 같은데,

    let str = "Hello, c= world!";
    str = str.replace("c=", "A");
    console.log(str);  // "Hello, A world!" 출력

    문제는 이 방식이 문자열에서 첫 번째로 일치하는 문자열만을 대체한다는 것이다.

     

    문자열에 존재하는 모든 문자열을 교체하려면 정규표현식과 함께 'g'(전역) 플래그를 사용해야 한다.

     

    그냥 바로 예를 들면 아래와 같다.

    let str = "Hello, c= world! c= Yeah!";
    str = str.replace(/c=/g, "A");
    console.log(str);  // "Hello, A world! A Yeah!" 출력

    자바와 파이썬에선 써보지 못한 방법이라 상당히 신선하게 다가왔다.

     

    JavaScript

     

    const rl = require('readline').createInterface({
        input: process.stdin,
        output: process.stdout,
    });
    
    rl.question('', (line) => {
        line = line.replace(/c=/g, 'A');
        line = line.replace(/c-/g, 'A');
        line = line.replace(/dz=/g, 'A');
        line = line.replace(/d-/g, 'A');
        line = line.replace(/lj/g, 'A');
        line = line.replace(/nj/g, 'A');
        line = line.replace(/s=/g, 'A');
        line = line.replace(/z=/g, 'A');
    
        console.log(line.length);
    
        rl.close();
    });

     

    반응형
    댓글
    공지사항
    최근에 올라온 글
    최근에 달린 댓글
    Total
    Today
    Yesterday
    링크
    «   2025/01   »
    1 2 3 4
    5 6 7 8 9 10 11
    12 13 14 15 16 17 18
    19 20 21 22 23 24 25
    26 27 28 29 30 31
    글 보관함