[백준] 11655 ROT13
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"으로 암호화한 다음 출력하는 프로그램을 작성하시오.
풀이에 참고한 아스키코드
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"으로 암호화한 다음 출력하는 프로그램을 작성하시오.
풀이(c++)
#include <bits/stdc++.h>
using namespace std;
string s;
int main(){
ios::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL);
getline(cin, s); //문자열 띄어쓰기까지 그대로 받기
for(char a : s){
if(a>='A' && a<'a'){ //대문자일경우
if(a+13 > 'Z'){ // 13을 더햇는데 Z보다 클경우
a = a - 26 + 13; //A로 돌아가서 13을 더함
}else{
a += 13;
}
}else if(a>='a' && a<='z'){ //소문자일경우
if(a+13 > 'z'){
a = a - 26 + 13;
}else{
a += 13;
}
}
cout<<a;
}
return 0;
}
풀이(python)
#ord() : 알파벳 => 아스키코드
#chr() : 아스키코드 => 알파벳으로
s = input()
for i in s:
if i.isupper(): #대문자
if ord(i)+13 > ord('Z'):
print(chr(ord(i) - 26 + 13), end='')
else: print(chr(ord(i) + 13), end='')
elif i.islower(): #소문자
if ord(i)+13 > ord('z'):
print(chr(ord(i) - 26 + 13), end='')
else:
print(chr(ord(i) + 13), end='')
else:
print(i, end='')
Author And Source
이 문제에 관하여([백준] 11655 ROT13), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다
https://velog.io/@youngcheon/백준-11655-ROT13
저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)
#include <bits/stdc++.h>
using namespace std;
string s;
int main(){
ios::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL);
getline(cin, s); //문자열 띄어쓰기까지 그대로 받기
for(char a : s){
if(a>='A' && a<'a'){ //대문자일경우
if(a+13 > 'Z'){ // 13을 더햇는데 Z보다 클경우
a = a - 26 + 13; //A로 돌아가서 13을 더함
}else{
a += 13;
}
}else if(a>='a' && a<='z'){ //소문자일경우
if(a+13 > 'z'){
a = a - 26 + 13;
}else{
a += 13;
}
}
cout<<a;
}
return 0;
}
#ord() : 알파벳 => 아스키코드
#chr() : 아스키코드 => 알파벳으로
s = input()
for i in s:
if i.isupper(): #대문자
if ord(i)+13 > ord('Z'):
print(chr(ord(i) - 26 + 13), end='')
else: print(chr(ord(i) + 13), end='')
elif i.islower(): #소문자
if ord(i)+13 > ord('z'):
print(chr(ord(i) - 26 + 13), end='')
else:
print(chr(ord(i) + 13), end='')
else:
print(i, end='')
Author And Source
이 문제에 관하여([백준] 11655 ROT13), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@youngcheon/백준-11655-ROT13저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)