티스토리 뷰

Java/Coding Test

[코딩테스트] 암호

Jane Kwon 2022. 2. 28. 10:43
반응형

 

문제

현수는 영희에게 알파벳 대문자로 구성된 비밀편지를 매일 컴퓨터를 이용해 보냅니다.

비밀편지는 현수와 영희가 서로 약속한 암호로 구성되어 있습니다.

비밀편지는 알파벳 한 문자마다 # 또는 *이 일곱 개로 구성되어 있습니다.

만약 현수가 “#*****#”으로 구성된 문자를 보냈다면 영희는 현수와 약속한 규칙대로 다음과 같이 해석합니다.

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

 

 

 

 

 

문제 풀이

 

[첫번째 풀이]

import java.util.Scanner;
  
public class Main {
  public static void main(String[] args){
    Scanner in = new Scanner(System.in);
    int count = Integer.parseInt(in.nextLine());
    String input = in.nextLine();

    input = input.replaceAll("#", "1").replaceAll("\\*", "0");

    for (int i=0; i<count; i++) {
      String str = input.substring(i*7, i*7+7);
      char num = (char) Integer.parseInt(str, 2);
      System.out.print(num);
    }
  }
}

(Time 163ms / Memory 27MB)

import java.util.Scanner;
  
public class Main {
  public String solution(int count, String input) {
    input = input.replaceAll("#", "1").replaceAll("\\*", "0");

    String result = "";
    for (int i=0; i<count; i++) {
      String str = input.substring(i*7, i*7+7);
      char num = (char) Integer.parseInt(str, 2);
      result += num;
    }

    return result;
  }
  
  public static void main(String[] args){
    Scanner in = new Scanner(System.in);
    int count = Integer.parseInt(in.nextLine());
    String input = in.nextLine();

    Main main = new Main();
    System.out.println(main.solution(count, input));
  }
}

(Time 156ms / Memory 27MB)

 

 

 

- replaceAll()을 이용해 #을 1로, *을 0으로 치환했다.

- for 문을 돌면서 7자리씩 끊어 Integer의 parseInt를 사용해 2진수를 10진수로 변환 후 아스키코드에 해당하는 값을 그대로 뿌려주었다.

 

 

 

 

 

반응형
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
TAG
more
«   2024/11   »
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
글 보관함