[오늘의 문제] 암호 해독

shlim55·2025년 10월 20일

코딩테스트

목록 보기
155/223

출처: https://school.programmers.co.kr/learn/courses/30/lessons/120892?language=python3

문제 설명
군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.

암호화된 문자열 cipher를 주고받습니다.
그 문자열에서 code의 배수 번째 글자만 진짜 암호입니다.
문자열 cipher와 정수 code가 매개변수로 주어질 때 해독된 암호 문자열을 return하도록 solution 함수를 완성해주세요.

제한사항
1 ≤ cipher의 길이 ≤ 1,000
1 ≤ code ≤ cipher의 길이
cipher는 소문자와 공백으로만 구성되어 있습니다.
공백도 하나의 문자로 취급합니다.
입출력 예
cipher code result
"dfjardstddetckdaccccdegk" 4 "attack"
"pfqallllabwaoclk" 2 "fallback"
입출력 예 설명
입출력 예 #1

"dfjardstddetckdaccccdegk" 의 4번째, 8번째, 12번째, 16번째, 20번째, 24번째 글자를 합친 "attack"을 return합니다.
입출력 예 #2

"pfqallllabwaoclk" 의 2번째, 4번째, 6번째, 8번째, 10번째, 12번째, 14번째, 16번째 글자를 합친 "fallback"을 return합니다.

내가 작성한 코드문

def solution(cipher, code):
    answer = ''
    
    for i in range(code-1, len(cipher), code):
            answer += cipher[i]
        
    return answer

트러브 슈팅
역시나 범위 설정이 힘들었다.
code-1인덱스 부터 시작한다.
len(cipher)길이 만큼 순회한다.
code씩 인덱스 건너뛴다.

다른사람의 풀이

def solution(cipher, code):
    answer = cipher[code-1::code]
    return answer

code-1부터 code만큼 건너뛴 인덱스 원소 넣는다.

def solution(cipher, code):

    return cipher[code-1::code]
profile
A Normal Programmer

0개의 댓글