코딩테스트
[프로그래머스][C++] 시저 암호
이쿠우우
2022. 3. 19. 17:22
반응형
https://programmers.co.kr/learn/courses/30/lessons/12926
코딩테스트 연습 - 시저 암호
어떤 문장의 각 알파벳을 일정한 거리만큼 밀어서 다른 알파벳으로 바꾸는 암호화 방식을 시저 암호라고 합니다. 예를 들어 "AB"는 1만큼 밀면 "BC"가 되고, 3만큼 밀면 "DE"가 됩니다. "z"는 1만큼 밀
programmers.co.kr
글쓴이의 답
개인적인 풀이 임으로
이것보다 더 좋은 알고리즘은 많음...
이렇게도 풀이하는구나.. 공유하기 위해 올림...
#include <string>
#include <vector>
#include <iostream>
using namespace std;
string solution(string s, int n) {
string answer = "";
for(size_t i=0; i < s.size(); i++){
if(' ' != s[i]){
if(('a' <= s[i]) && ('z' >= s[i]) ){
if('z' < (s[i] + n)){
int temp = (s[i] + n) - 'z' ;
answer += ('a' + (temp-1));
}
else{
answer += (s[i] + n);
}
}
else{
if('Z' < (s[i] + n)){
int temp = (s[i] + n) - 'Z' ;
answer += ('A' + (temp-1));
}
else{
answer += (s[i] + n);
}
}
}
else{
answer += s[i];
}
}
return answer;
}
꾸준히 하다보면 실력이 늘겠지..
반응형