ROT13은 카이사르 암호의 일종으로 영어 알파벳을 13글자씩 밀어서 만든다.
예를 들어, "Baekjoon Online Judge"를 ROT13으로 암호화하면 "Onrxwbba Bayvar Whqtr"가 된다. ROT13으로 암호화한 내용을 원래 내용으로 바꾸려면 암호화한 문자열을 다시 ROT13하면 된다. 앞에서 암호화한 문자열 "Onrxwbba Bayvar Whqtr"에 다시 ROT13을 적용하면 "Baekjoon Online Judge"가 된다.
ROT13은 알파벳 대문자와 소문자에만 적용할 수 있다. 알파벳이 아닌 글자는 원래 글자 그대로 남아 있어야 한다. 예를 들어, "One is 1"을 ROT13으로 암호화하면 "Bar vf 1"이 된다.
문자열이 주어졌을 때, "ROT13"으로 암호화한 다음 출력하는 프로그램을 작성하시오.
첫째 줄에 알파벳 대문자, 소문자, 공백, 숫자로만 이루어진 문자열 S가 주어진다. S의 길이는 100을 넘지 않는다.
첫째 줄에 S를 ROT13으로 암호화한 내용을 출력한다.
Baekjoon Online Judge
One is 1
Onrxwbba Bayvar Whqtr
Bar vf 1
아스키코드 상 A~Z는 65~90, a~z는 97~122 이므로 대문자, 소문자를 나눠서 판단함.
알파벳에 13을 더한 값이 대문자의 경우 90을, 소문자의 경우 122를 넘어간다면 13을 빼주고, 아닌 경우 13을 더해줌.
C++ 의 경우 getline으로 공백을 포함한 문자열을 받아온 뒤, 각 조건을 판단하여 문자에 13을 빼거나 더해서 변경시켜줌.
Java는 String 객체를 변경할 수 없기 때문에 Stringbuilder를 사용하여 문자열을 새로 만들고 출력함.
#include <iostream>
using namespace std;
int main(void)
{
string str;
getline(cin, str);
for (int i = 0; i < str.length(); i++)
{
// 대문자일 경우?
if (str[i] >= 'A' && str[i] <= 'Z')
{
if (str[i] + 13 > 90)
str[i] -= 13;
else
str[i] += 13;
}
// 소문자일 경우?
else if (str[i] >= 'a' && str[i] <= 'z')
{
if (str[i] + 13 > 122)
str[i] -= 13;
else
str[i] += 13;
}
}
cout << str << "\n";
}
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class Main {
public static void main(String[] args) throws IOException {
StringBuilder sb = new StringBuilder();
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
String str = br.readLine();
for (int i = 0; i < str.length(); i++)
{
// 대문자일 경우?
if (str.charAt(i) >= 'A' && str.charAt(i) <= 'Z')
{
if (str.charAt(i) + 13 > 90)
sb.append((char)(str.charAt(i)-13));
else
sb.append((char)(str.charAt(i)+13));
}
// 소문자일 경우?
else if (str.charAt(i) >= 'a' && str.charAt(i) <= 'z')
{
if (str.charAt(i) + 13 > 122)
sb.append((char)(str.charAt(i)-13));
else
sb.append((char)(str.charAt(i)+13));
}
// 공백, 숫자인 경우
else
sb.append(str.charAt(i));
}
System.out.println(sb);
}
}