원 소스에서는 'a' 를 뺍니다.
위에서 모두 소문자로 바꾼 상태이고, a에서 a를 빼면 0이 되기 때문에 몇번째 글자인지 확인하는 것입니다.
즈티브삽스 님이 쓰신 글 :
: 구글에서 찾은 오리지널 코드(
http://www.cplusplus.com/articles/4iLN8vqX/)를 재방식에 맞춰서 다시 해석했는데요.
:
: 사용자가 영어로 문장을 입력하면, 전부 소문자로 바꾸고 ROT13으로 암호화하는 방식입니다. 한글, 물음표 등은 그냥 그대로 출력하구요.
:
: 이 코드에서 왜 중간에 a값을 더하기 하는지 알고 싶습니다. (아래에 문제가 되는 줄에 코멘트로 표기했습니다)
:
: 그리고 이렇게 ROT13으로 암호화한 문장을 다시 해독하는 코드를 적고 싶은데, 잘 안되네요. 도움이 필요합니다.
:
:
: string rotate13(string origString)
: {
: //Rot13
: //reference:
: //http://www.cplusplus.com/articles/4iLN8vqX/
:
: string alterString;
:
: //convert capital to smaller.
: for(size_t i = 0; i < origString.size(); i++)
: {
: origString[i] = tolower(origString[i]);
: }
:
: //roate13
: for(size_t i = 0; i < origString.length(); i++)
: {
: //handle alphabet value.
: if(isalpha(origString[i]))
: {
: if(tolower(origString[i] + 'a') < 14) //궁금합니다. 왜 'a' 값을 더하는거죠??????????
: {
: alterString.append(1, origString[i] + 13);
: }
: else
: {
: alterString.append(1, origString[i] - 13);
: }
: }
: else//handle non-alphabet value.
: {
: alterString.append(1, origString[i]);
: }
: }
:
: return alterString;
: }