문제 링크
문제
2023 APC를 총괄하고 있는 A.N.S.I 부회장 현빈이는 문제들을 검수하던 중 이상한 점을 발견하였다. 그것은 몇몇 단어들이 비슷하게 생겼지만, 다른 철자로 되어있었던 것이었다. 어리둥절한 현빈이는 누가 이러한 짓을 저질렀는지 고민하던 와중, 어제 선우와 했던 대화가 문득 떠올랐다.
가뜩이나 A.N.S.I 부회장으로서 바쁜 현빈이는 철자가 바뀐 단어들을 다시 원래대로 고치기가 매우 귀찮았다. 다행히도 현빈이는 평소 선우가 어떠한 철자를 바꾸는지 알고 있다. 선우는 알파벳 소문자에 대해서만 철자를 바꾸며, 목록은 다음과 같다.
철자가 바뀐 단어들을 보며 어지러웠던 현빈이는 단어에 있는 알파벳의 절반 이상이 바뀌어 있으면 해석을 포기하기로 하였다. 표를 참고하여 현빈이가 주어지는 단어들을 해석할 수 있는지 알아보자.
입력
첫 번째 줄에는 정수 이 주어진다. (1 ≤ N ≤ 100)
두 번째 줄에는 100 이하이다.
줄에 걸쳐 선우가 바꾸어 놓은 단어들이 주어진다. 선우가 바꾼 단어는 본래 알파벳 소문자로만 구성되어 있었으며, 단어의 길이는출력
현빈이가 주어진 단어를 해석할 수 있다면 선우가 바꾸기 전의 원래 단어를, 해석을 포기했다면 I don't understand를 줄에 걸쳐 출력한다.
예제 입력 1
4
a;ou
d!sc0\'ery
kdollar
\'e[70r
예제 출력 1
ajou
discovery
kdollar
I don't understand
알고리즘 분류
- 문자열
풀이
바꾼 문자를 원래 문자로 되돌리면서 바꾼 문자의 개수를 센다.
바꾼 문자의 개수가 원래 문자열의 길이의 절반 이상이면 I don't understand를 출력하고, 그게 아니라면 원래 문자열을 출력한다.
코드
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#define FASTIO cin.tie(0); cout.tie(0); ios::sync_with_stdio(false);
using namespace std;
int N;
int Count;
string S, Answer;
void init() {
Count = 0;
Answer = "";
}
void settings() {
for (int i = 0; i < S.size(); i++) {
char Now = S[i];
if (Now == '@') {
Answer += 'a';
Count++;
}
else if (Now == '[') {
Answer += 'c';
Count++;
}
else if (Now == '!') {
Answer += 'i';
Count++;
}
else if (Now == ';') {
Answer += 'j';
Count++;
}
else if (Now == '^') {
Answer += 'n';
Count++;
}
else if (Now == '0') {
Answer += 'o';
Count++;
}
else if (Now == '7') {
Answer += 't';
Count++;
}
else if (Now == '\\') {
if (S[i + 1] == '\'') {
i++;
Answer += 'v';
Count++;
}
else if ((S[i + 1] == '\\') && (S[i + 2] == '\'')) {
i += 2;
Answer += 'w';
Count++;
}
}
else {
Answer += Now;
}
}
}
void find_Answer() {
if ((int)Answer.size() <= (Count * 2)) {
cout << "I don't understand\n";
}
else {
cout << Answer << "\n";
}
}
void input() {
cin >> N;
for (int i = 0; i < N; i++) {
init();
cin >> S;
settings();
find_Answer();
}
}
int main() {
FASTIO
input();
return 0;
}
'BOJ > Silver' 카테고리의 다른 글
[BOJ/Silver 2] 백준 28256 초콜릿 보관함(C++) (0) | 2023.06.25 |
---|---|
[BOJ/Silver 1] 백준 28078 중력 큐(C++) (0) | 2023.06.16 |
[BOJ/Silver 5] 백준 28136 원, 탁!(C++) (0) | 2023.05.30 |
[BOJ/Silver 2] 백준 18126 너구리 구구(C++) (0) | 2023.05.14 |
[BOJ/Silver 1] 백준 27375 금공강 사수(C++) (0) | 2023.04.12 |