시간 제한 | 메모리 제한 | 제출 | 정답 | 맞은 사람 | 정답 비율 |
---|---|---|---|---|---|
1 초 | 128 MB | 666 | 294 | 272 | 52.510% |
문제
암호학에서 치환 암호(substitution cipher)란, 평문에 들어있는 각각의 문자를 주어진 치환 방법으로 암호화하는 방법 중 하나다.
가장 단순한 방법은 평문의 알파벳을 암호문의 알파벳으로 대치시켜 치환시키는 것이다.
예를 들어, 아래와 같은 알파벳 대치표가 주어졌다고 하자.
- 평문 알파벳 대치표 : abcdefghijklmnopqrstuvwxyz
- 암호문 알파벳 대치표 : wghuvijxpqrstacdebfklmnoyz
위에 주어진 치환 방법을 통해 암호화하면 평문 "hello there"은 "xvssc kxvbv"가 된다.
한 가지 흥미로운 점은 영어 문법 특성상, 알파벳 'e'가 다른 영문 알파벳에 비해 자주 쓰인다는 것이다.
즉, 암호문 알파벳 대치표 없이 암호문을 복호화하려 할 때, 암호문 알파벳 빈도수를 체크하면 암호문 알파벳 빈도수 중 가장 빈번하게 나타나는 알파벳이 'e'라는 사실을 유추해볼 수 있다.
위 방법으로 암호문 알파벳의 빈도수를 체크하고, 가장 빈번하게 나타나는 문자를 출력하는 프로그램을 작성하면 된다.
만약 주어진 암호문에서 가장 빈번하게 나타나는 문자가 여러 개일 경우, 그 빈번한 문자 중 어느 것이 평문 알파벳 'e'를 가리키는지 확실하게 알 수 없기 때문에 "모르겠음"을 의미하는 '?'를 출력하면 된다.
입력
입력의 T(1 ≤ T ≤ 20)는 테스트 케이스로, 입력 제일 상단에 주어진다. 각각의 테스트 케이스는 한 줄마다 소문자와 공백으로 이루어진 영어 문장이 주어진다. 이 문장의 길이는 적어도 1이상이며 255이하다.
출력
각각의 테스트 케이스에 대해, 가장 빈번하게 나타나는 문자를 출력하거나 빈번하게 나타나는 문자가 여러 개일 경우 '?'를 출력한다.
예제 입력 1
3
asvdge ef ofmdofn
xvssc kxvbv
hull full suua pmlu
예제 출력 1
f
v
?
코드
//*********** 메모리:16000KB, 시간:156ms
import java.io.*;
import java.util.*;
public class p9046 {
static int t;
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringBuilder sb;
t = Integer.parseInt(br.readLine());
for (int i = 0; i < t; i++) {
String line = br.readLine();
sb = new StringBuilder();
int[] alpha = new int[26];
for (char c : line.replaceAll(" ", "").toCharArray()) {
alpha[c-'a'] ++;
}
int[] copy = alpha.clone();
Arrays.sort(copy);
if (copy[alpha.length - 1] == copy[alpha.length - 2]) {
sb.append("?");
} else {
int max = -1;
String c = "";
for (int j = 0; j < 26; j++) {
if (max < alpha[j]) {
max = alpha[j];
c = Character.toString(j + 97);
}
}
sb.append(c);
}
sb.append("\n");
bw.write(sb.toString());
}
bw.flush();
bw.close();
br.close();
}
}
더 좋은 풀이
import java.io.InputStreamReader;
import java.io.BufferedReader;
import java.io.IOException;
public class Main {
public static void main(String[] args) throws NumberFormatException, IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int n = Integer.parseInt(br.readLine());
StringBuilder sb = new StringBuilder();
for (int i = 0; i < n; i++) {
int[] result = new int[26];
char[] arr = br.readLine().toCharArray();
for (char c : arr) {
if (c >= 'a' && c <= 'z') {
result[c - 'a']++;
}
}
int max = 0;
for (int e : result) {
if (e > max) max = e;
}
int count = 0;
int answer = 0;
for (int j = 0; j < 26; j++) {
if (result[j] == max) {
count++;
answer = j;
}
}
sb.append(count == 1 ? (char)('a' + answer) : "?").append(System.lineSeparator());
}
System.out.print(sb.toString());
}
}
'알고리즘 > [ Baekjoon ]' 카테고리의 다른 글
[ BOJ ][JAVA][9095] 1, 2, 3 더하기 (0) | 2021.04.26 |
---|---|
[ BOJ ][JAVA][9079] 동전 게임 (0) | 2021.04.26 |
[ BOJ ][JAVA][9019] DSLR (0) | 2021.04.26 |
[ BOJ ][JAVA][9012] 괄호 (0) | 2021.04.26 |
[ BOJ ][JAVA][7576] 토마토 (0) | 2021.04.26 |