[백준/BOJ] 11655번_ROT 13 (C++/Java)

JIMIN·2023년 2월 6일

BOJ_Bronze

목록 보기
75/75

https://www.acmicpc.net/problem/11655

문제


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를 사용하여 문자열을 새로 만들고 출력함.


C++ 소스코드


#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";
}

Java 소스코드


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);
    }
}
profile
잘못된 코드나 정보가 있다면 알려주세요! 👋🏻

0개의 댓글