Java/Java 알고리즘

백준 10770번 Rövarspråket JAVA 구현해보기

kimc 2022. 6. 3. 16:46

```

백준 10770번 Rövarspråket JAVA 구현해보기

```

이번 글을 통해 배워갈 내용

  1. 백준 10770번 Rövarspråket 풀이

https://www.acmicpc.net/problem/10770

 

10770번: Rövarspråket

In Sweden, there is a simple child’s game similar to Pig Latin called Rövarspråket (Robbers Language). In the CCC version of Rovarspr ¨ aket, every consonant is replaced by three letters, in the following order: the consonant itself; the vowel closest

www.acmicpc.net

 

백준 번 제목은

난이도 브론즈 등급의 문제로서

a부터 z까지의 영소 문자로 이뤄진 문자열이 주어질 때

 

 a, e, i, o, u는 모음 나머지는 자음으로 간주하고

각 자음은

주어진 자음 + 자음에서 가장 가까운 모음(양쪽이 같으면 첫 번째) + 알파벳순 다음 자음

으로 바꿔서

출력해주면 됩니다.

(예를 들어 j는 jik)


30분 정도 위에 링크를 방문하셔서 풀어보시고

안 풀리시는 경우에만 아래 해답을 봐주시면 감사하겠습니다.


조건에 맞춰서

스위치 케이스 돌려서 출력하였습니다.

 

만약 이게 실무 코드였다면

패턴을 발견해서

코드 길이를 줄여서 읽는 사람을 배려했겠지만

 

시간 관계상

스위치를 썼습니다.

 

package com.bjoon;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;

public class Main {

    public static void main(String[] args) throws IOException {
        final BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        final String input01 = br.readLine();
        System.out.print(solution(input01));
    }

    private static String solution(String input01) {

        List<Character> robbersLanguage = new ArrayList<>();

        for (char ch : input01.toCharArray()) {
            switch (ch) {
                case 'a':
                case 'e':
                case 'i':
                case 'o':
                case 'u':
                    robbersLanguage.add(ch);
                    break;
                case 'b':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('a');
                    robbersLanguage.add('c');
                    break;
                case 'c':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('a');
                    robbersLanguage.add('d');
                    break;
                case 'd':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('e');
                    robbersLanguage.add('f');
                    break;
                case 'f':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('e');
                    robbersLanguage.add('g');
                    break;
                case 'g':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('e');
                    robbersLanguage.add('h');
                    break;
                case 'h':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('i');
                    robbersLanguage.add('j');
                    break;
                case 'j':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('i');
                    robbersLanguage.add('k');
                    break;
                case 'k':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('i');
                    robbersLanguage.add('l');
                    break;
                case 'l':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('i');
                    robbersLanguage.add('m');
                    break;
                case 'm':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('o');
                    robbersLanguage.add('n');
                    break;
                case 'n':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('o');
                    robbersLanguage.add('p');
                    break;
                case 'p':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('o');
                    robbersLanguage.add('q');
                    break;
                case 'q':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('o');
                    robbersLanguage.add('r');
                    break;
                case 'r':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('o');
                    robbersLanguage.add('s');
                    break;
                case 's':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('u');
                    robbersLanguage.add('t');
                    break;
                case 't':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('u');
                    robbersLanguage.add('v');
                    break;
                case 'v':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('u');
                    robbersLanguage.add('w');
                    break;
                case 'w':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('u');
                    robbersLanguage.add('x');
                    break;
                case 'x':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('u');
                    robbersLanguage.add('y');
                    break;
                case 'y':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('u');
                    robbersLanguage.add('z');
                    break;
                case 'z':
                    robbersLanguage.add(ch);
                    robbersLanguage.add('u');
                    robbersLanguage.add('z');
                    break;
                default:
                    break;
            }
        }
        StringBuilder sb = new StringBuilder();
        robbersLanguage.forEach(sb::append);
        return sb.toString();
    }

}

// https://codemasterkimc.tistory.com

 

 

 

읽어주셔서 감사합니다

 

무엇인가 얻어가셨기를 바라며

 

오늘도 즐거운 코딩 하시길 바랍니다 ~ :)

 


 

728x90