개발자 미니민의 개발스터디

[백준 JAVA] 2941번 풀이 - 크로아티아 알파벳

by mini_min

import java.io.IOException;
import java.util.*;

/**
 * 2941번 풀이
 * 예전에는 운영체제에서 크로아티아 알파벳을 입력할 수가 없었다. 따라서, 다음과 같이 크로아티아 알파벳을 변경해서 입력했다.
 * 예를 들어, ljes=njak은 크로아티아 알파벳 6개(lj, e, š, nj, a, k)로 이루어져 있다. 단어가 주어졌을 때, 몇 개의 크로아티아 알파벳으로 이루어져 있는지 출력한다.
 *  dž는 무조건 하나의 알파벳으로 쓰이고, d와 ž가 분리된 것으로 보지 않는다. lj와 nj도 마찬가지이다. 위 목록에 없는 알파벳은 한 글자씩 센다.
 *
 * 첫째 줄에 최대 100글자의 단어가 주어진다. 알파벳 소문자와 '-', '='로만 이루어져 있다.
 */
public class Main3 {
    public static void main(String[] args) throws IOException {

        Scanner sc = new Scanner(System.in);

        String word = sc.next();

        HashMap<String, Integer> map = new LinkedHashMap<>();

        map.put("c=", 1);
        map.put("c-", 2);
        map.put("dz=", 3);
        map.put("d-", 4);
        map.put("lj", 5);
        map.put("nj", 6);
        map.put("s=", 7);
        map.put("z=", 8);

        for ( String key : map.keySet() ){
            if ( word.contains(key)){
                word = word.replaceAll(key, "o");
//                System.out.println(key + " ! ");
//                System.out.println("word 는? " + word);
            }
        }
        System.out.println(word.length());

        sc.close();
    }
}

 

풀이

👩🏻 LinkedHashMap 은 순서를 보장한다! ✨✨

순서를 보장해야 dz= 와 z= 에서 예외가 발생하지 않는다. (Hashmap 썼다가 ddz=z= 를 4글자로 인식해서 혼났음)

 

맵에 크로아티아 알파벳을 저장해두고, 검색한 다음 해당 알파벳이 있으면 다른 값으로 대체해서 글자수를 셌다.

 

 

 

 

블로그의 정보

개발자 미니민의 개발로그

mini_min

활동하기