[C++] 백준(BOJ) - 11655 : ROT13

인프런에 있는 큰돌님의 강의 10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트를 듣고 정리한 필기입니다.

문제

백준(BOJ) - 11655 : ROT13(링크)

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으로 암호화한 내용을 출력한다.

알고리즘

  1. 구현
  2. 문자열
  3. 아스키코드

풀이

  • string을 공백 포함하여 담는 getline 함수를 이용해서 string 전체를 입력받는다
  • 입력받은 str을 순회하며 13번째 알파벳임 m을 기준으로 ROT13 코드를 구현한다. (소문자, 대문자 두 가지)
  • 공백은 예외처리 한다

코드

#include <bits/stdc++.h>
using namespace std;

int main() {
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);

    string str;
    getline(cin, str);

    for (int i = 0; i < str.size(); i++)
    {
        if (str[i] == ' ') continue;
        
        if (str[i] >= 'a' && str[i] <= 'm') str[i] = str[i] + 13;
        else if (str[i] >= 'n' && str[i] <= 'z') str[i] = str[i] - 13;
        else if (str[i] >= 'A' && str[i] <= 'M') str[i] = str[i] + 13;
        else if (str[i] >= 'N' && str[i] <= 'Z') str[i] = str[i] - 13;
    }

    /*
    a b c d e
    f g h i j
    k l m n o
    p q r s t
    u v w x y 
    z
    */

    cout << str << '\n';

    return 0;
}

평가

  • string, alphabet, 아스키 코드 능숙하게 사용하기
  • 아스키코드로 문자열 카운팅 연습
  • 예외처리 꼼곰하게 하기

© 2023 Jinsoo Lee. All rights reserved.

Powered by Hydejack v9.1.6