본문 바로가기
Java/Coding-Test

[Java] 1-12 암호

by JS1111 2022. 1. 16.

문제

현수는 영희에게 알파벳 대문자로 구성된 비밀편지를 매일 컴퓨터를 이용해 보냅니다.
비밀편지는 현수와 영희가 서로 약속한 암호로 구성되어 있습니다.
비밀편지는 알파벳 한 문자마다 # 또는 이 일곱 개로 구성되어 있습니다.
만약 현수가 `#****
#`으로 구성된 문자를 보냈다면 영희는 현수와 약속한 규칙대로 다음과 같이 해석합니다.

  1. #*****#를 일곱자리의 이진수로 바꿉니다. #은 이진수의 1로, *이진수의 0으로 변환합니다. 결과는 “1000001”로 변환됩니다.
  2. 바뀐 2진수를 10진수화 합니다. 1000001을 10진수화 하면 65가 됩니다.
  3. 아스키코드가 65문자로 변환합니다. 즉 아스키코드 65는 대문자 'A'입니다.
    참고로 대문자들의 아스키코드는 'A'는 65번, ‘B'는 66번, ’C'는 67번 등 차례대로 1씩 증가하여 ‘Z'는 90번입니다.

현수가 4개의 문자를 다음과 같이 신호로 보냈다면
#****###**#####**#####**##**
이 신호를 4개의 문자신호로 구분하면
#****## --> 'C'
#**#### --> 'O'
#**#### --> 'O'
#**##** --> 'L'
최종적으로 COOL로 해석됩니다.
현수가 보낸 신호를 해석해주는 프로그램을 작성해서 영희를 도와주세요.

입력

첫 줄에는 보낸 문자의 개수(10을 넘지 안습니다)가 입력된다. 다음 줄에는 문자의 개수의 일곱 배 만큼의 #또는 * 신호가 입력됩니다.
현수는 항상 대문자로 해석할 수 있는 신호를 보낸다고 가정합니다.

출력

현수는 항상 대문자로 해석할 수 있는 신호를 보낸다고 가정합니다.

예시 입력

4
#****###**#####**#####**##** 

예시 출력

COOL

출처

인프런 - 자바-알고리즘-문제풀이-코테대비

내 풀이

private static String depress(int num, String input) {
    StringBuilder sb = new StringBuilder();
    String binaries = input.replace('#', '1').replace('*', '0');
    for (int i = 0; i < num; i++) {
        String binary = binaries.substring(i * 7, (i + 1) * 7);
        int ascii = Integer.parseInt(binary, 2);
        sb.appendCodePoint(ascii);
    }
    return sb.toString();
}

replace를 사용하여 이진수로 바꾸고, substring으로 7개씩 잘라서, parseInt로 10진수로 변환하여 문자열에 추가한다

'Java > Coding-Test' 카테고리의 다른 글

[Java] 2-5 소수(에라토스테네스 체)  (0) 2022.01.18
[Java] 2-4 피보나치 수열  (0) 2022.01.17
[Java] 1-11 문자열 압축  (0) 2022.01.16
[Java] 1-10 가장 짧은 문자거리  (0) 2022.01.16
[Java] 1-9 숫자만 추출  (0) 2022.01.15

댓글