• Quiz
  • Test Cases
  • Solution
  • Solution 1
  • Solution 2
Recursion 초급

암호문자

알파벳을 어떤 특정 방법으로 섞어서 암호화하는 아주 간단한 방법을 고안해 냈습니다. 이 방법으로 만든 문장은 읽기는 어렵지만, 매우 쉽게 원래 문장으로 바꿀 수 있습니다.

문자열 S를 암호화할 때, 처음에 비어 있는 문자열 R에 다음과 같은 방법으로 문자를 추가합니다.

  • S의 가운데 글자를 더합니다 (문자열 S의 길이가 짝수인 경우 가운데 글자는 가운데에 있는 두 글자의 왼쪽으로 정의합니다)
  • 가운데 글자의 왼쪽에 있는 S의 모든 문자열을 암호화하여 R에 추가합니다 (글자가 있는 경우)
  • 가운데 글자의 오른쪽에 있는 S의 모든 문자열을 암호화하여 R에 추가합니다 (글자가 있는 경우)

예를 들어 문자열 abc를 암호화하려면 먼저 b를 가져온 후 암호화 된 버전의 ac를 추가하여 bac를 반환합니다.

abcxcba를 암호화하면 xbacbca를 얻을 수 있습니다. 즉, 가운데 글자 x를 취하고 암호화 된 버전 bac 다음 암호화 된 버전의 bca를 추가합니다.

예제 1

입력

S = "abc"  

출력

"bac"

예제 2

입력

S = "abcxcba"

출력

"xbacbca"

예제 3

입력

S = "WebAddin"

출력

"dbeWAidn"

Test Case 1

Input

s = "abc"

Output

"bac"

Test Case 2

Input

s = "abcxcba"

Output

"xbacbca"

Test Case 3

Input

s = "WebAddin"

Output

"AeWbddin"

Test Case 4

Input

s = "Wplus Coding"

Output

" lWpusdConig"

Test Case 5

Input

s = "Hello World!"

Output

" lHelorWodl!"
  • My Answer
  • Lecture
  • Output
                                            
W+코딩 알고리즘 강의

프로그래밍을 이해하는데 꼭 필요한 알고리즘을 쉽고 빠르게 배울 수 있도록 준비한 강의 입니다.

코딩테스트를 준비하시는 분, 알고리즘에 대해서 전반적으로 공부하고자 하는 분들을 위해 꼭 필요한 토픽을 모아서 기초부터 고급 문제까지 단계적으로 구성되어 있습니다.

프로그래밍 언어는 JavaScript · Java · Python · C++ · C# 을 이용하여 브라우저에서 직접 프로그램을 작성 및 실행할 수 있으며, 알고리즘 강의를 통해 주어진 문제를 응용하여 다양한 솔루션을 작성하고 온라인에서 바로 테스트하면서, 알고리즘에 대해 좀 더 깊은 이해를 도와 드립니다.

코딩테스트 문제해설

Light Mode

온라인으로 코딩문제 풀면서 학습하는 사이트를 찾고 계신가요? W+코딩에서는 코딩공부 하면서 헷갈리는 부분을 알기 쉽고 정확하게 알려드립니다.

알고리즘 코드해설

Dark Mode

바이너리트리, 링드리스트, 그래프, 다이나믹 프로그래밍, 그리디 등등등... JavaScript, Java, Python, C++, C# 솔루션을 정확하고 알기 쉽게 설명해 드립니다.