ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [JAVA] 알고리즘 문제 - 암호 해독하기
    Java 알고리즘 문제/자바(Java) 알고리즘 문제풀이 입문 2023. 8. 9. 10:21
    반응형

    암호 해독하기

     

    예시 출력 1

    설명

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

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

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

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

    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을 넘지 안습니다)가 입력된다. 다음 줄에는 문자의 개수의 일곱 배 만큼의 #또는 * 신호가 입력됩니다.

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

     

    출력

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

     

    예시 입력 1 

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

     

    예시 출력 1

    COOL

     

     

    import java.util.Scanner;
    
    public class Main {
     
    	public String test(int n, String str) {
    		String answer ="";
    		int a =0;
    		for(int i=0; i<n; i++) {
    			String tmp = str.substring(0,7).replace('#', '1').replace('*', '0');
    			int num = Integer.parseInt(tmp, 2);
    			str = str.substring(7);
    			answer +=(char)num;
    		}
    	
    				
    		return answer;
    	}
    	
    	public static void main(String[] args){
    		Main t = new Main();
    		Scanner kb = new Scanner(System.in);
    		int n = kb.nextInt();
    		String str = kb.next();
    		System.out.println(t.test(n, str));
        }
    }

     

    우선 문제가 다소 생소하여 겁을 먹었지만 아주 간단한 문제였다.

    암호를 전달받으면 해당 암호를 해석하기만 하면 되는데 규칙만 잘 파악하면 된다.

    암호는 #, * 이렇게 두가지 기호로 오는데 7자리씩 끊어서 우리는 치환해주면된다.

     

    	public static void main(String[] args){
    		Main t = new Main();
    		Scanner kb = new Scanner(System.in);
    		int n = kb.nextInt();
    		String str = kb.next();
    		System.out.println(t.test(n, str));
        }
    }

    main에서 우선 문자열길이와, 그 길이에 맞는 문자열을 입력받는다.

     

    	public String test(int n, String str) {
    		String answer ="";
    		int a =0;
    		for(int i=0; i<n; i++) {
    			String tmp = str.substring(0,7).replace('#', '1').replace('*', '0');
    			int num = Integer.parseInt(tmp, 2);
    			str = str.substring(7);
    			answer +=(char)num;
    		}
    				
    		return answer;
    	}

    for문을 통해 입력받은 문자열을 substring을 통하여 # -> 1 , * -> 0으로 치환한다.

    7자리를 치환한 후에 7자리 뒤의 문자열을 순서대로 치환해야 하기때문에

    str = str.subsring(7)을 통해 나머지 문자열도 치환해준다. 

     

    그리고 지금 치환된 문자열을 다시 숫자로 치환해줘야하는데 이때 

    int num = Integer.parseInt(tmp, 2);

    를 사용하여 치환한 문자열들을 정수화 시킨 후에, 출력한 진수를 입력해주면된다. 

    그리고 다시 문자열로 치환을 위해 

    answer +=(char)num을 사용해주었다. 

    반응형

    댓글

Designed by Tistory.