[백준 JAVA] 2941번 풀이 - 크로아티아 알파벳
by mini_minimport 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글자로 인식해서 혼났음)
맵에 크로아티아 알파벳을 저장해두고, 검색한 다음 해당 알파벳이 있으면 다른 값으로 대체해서 글자수를 셌다.
'매일매일 알고리즘 공부' 카테고리의 다른 글
[백준 JAVA] 1436번 풀이 - 영화감독 숌 (0) | 2023.07.31 |
---|---|
[백준 JAVA] 2444번 풀이 - 별 찍기 7 (0) | 2023.07.29 |
[백준 JAVA] 1193번 풀이 - 분수 찾기 (0) | 2023.07.27 |
[백준 JAVA] 2869번 풀이 - 달팽이는 올라가고 싶다 🔥다시🔥 (0) | 2023.07.26 |
[백준 JAVA] 2292번 풀이 - 벌집 (0) | 2023.07.26 |
블로그의 정보
개발자 미니민의 개발로그
mini_min