현수는 영희에게 알파벳 대문자로 구성된 비밀편지를 매일 컴퓨터를 이용해 보냅니다.
비밀편지는 현수와 영희가 서로 약속한 암호로 구성되어 있습니다.
비밀편지는 알파벳 한 문자마다 # 또는 *이 일곱 개로 구성되어 있습니다.
만약 현수가 “#*#”으로 구성된 문자를 보냈다면 영희는 현수와 약속한 규칙대로 다음과 같이 해석합니다.
“#*#”를 일곱자리의 이진수로 바꿉니다. #은 이진수의 1로, *이진수의 0으로 변환합니다. 결과는 “1000001”로 변환됩니다.
바뀐 2진수를 10진수화 합니다. “1000001”을 10진수화 하면 65가 됩니다.
아스키 번호가 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;
class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int num = sc.nextInt();
String str = sc.next();
System.out.println(solution(num, str));
}
public static String solution(int n, String str) {
String answer ="";
for (int i=0; i<n; i++) {
String tmp = str.substring(0,7).replace('#','1').replace('*', '0');
int number = Integer.parseInt(tmp,2);
answer += (char)number;
str = str.substring(7);
}
return answer;
}
}
입력받은 암호는 7개마다 끊어줘야한다.
그렇기 때문에 substring()메소드를 통해서 7개마다 끊어주고
끊어준 문자열을 1,0으로 치환하고 2진수로 바꿔준다.
다음에는 str에 7개는 자른 나머지 문자열만 남어야하기 때문에 substring(7)를 해주었다
이번 문제를 풀면서 replace() 와 replaceAll()의 차이가 궁금해졌다.
replace() 와 replaceAll()의 가장 큰 차이는 정규식의 사용가능 여부이다.
replaceAll() 은 정규식이 사용가능하다.
정규식이란 문자열에서 일정한 패턴이나 규칙을 찾아내는 일종의 형식 언어라고 할 수 있다.