ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [코테] 문제 12.암호
    알고리즘/코테 2024. 11. 1. 14:35

     

    2. 암호

     

    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'

     

    입력

    첫 줄에는 보낸 문자의 개수(10을 넘지 안습니다)가 입력된다. 다음 줄에는 문자의 개수의 일곱 배 만큼의 #또는 * 신호가 입력됩니다.

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

     

    출력

    영희가 해석한 문자열을 출력합니다.

    예시 입력 1 

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

    예시 출력 1

    COOL

     

     

     

    Scanner sc = new Scanner(System.in);
    
         int num = Integer.parseInt(sc.nextLine());
         String str = sc.nextLine();
         String answer = "";
    
         for(int i=0; i<num; i++){
            String s = str.substring(0,7).replace('#','1').replace('*','0');
            str = str.substring(7);  // substring을 이용해서 7번째~끝까지 자름
            int n = Integer.parseInt(s,2);  // parseInt를 통해 2진수로 변환
    
            answer+=(char)n;  // char은 원래 아스키코드 숫자형으로 처리되므로, 문자형으로 변환시켜 저장.
         }
    
         System.out.print(answer);
Designed by Tistory.