본문 바로가기
algorithm

[프로그래머스]암호 해독 - java, python

by skysline 2023. 3. 1.
반응형

암호 해독

문제 설명

군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.
암호화된 문자열 cipher를 주고받습니다.
그 문자열에서 code의 배수 번째 글자만 진짜 암호입니다.

문자열 cipher와 정수 code가 매개변수로 주어질 때 해독된 암호 문자열을 return하도록 solution 함수를 완성해주세요.

입출력 예


입출력 예 #1

  • "dfjardstddetckdaccccdegk" 의 4번째, 8번째, 12번째, 16번째, 20번째, 24번째 글자를 합친 "attack"을 return합니다.

입출력 예 #2

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

java code

class Solution {
    public String solution(String cipher, int code) {
        String answer = "";
        for (int i = code; i <= cipher.length(); i++) {
            if(i%code ==0){
                answer += cipher.charAt(i-1);
            }
        }
        return answer;
    }
}
  • for (int i = 1; i <= cipher.length(); i++) { 
    • i가 code부터 cipher 문자열의 길이만큼 반복하는 반복문 시작
    • 문자열의 각 인덱스를 확인하기 위한 반복문입니다.
  • if(i%code ==0){ 
    • i가 code로 나누어 떨어지는지 확인하는 조건문 시작
    • code로 나누어 떨어지는 경우마다 문자를 추출합니다.
  • answer += cipher.charAt(i-1); 
    • answer 문자열에 cipher 문자열의 i-1번째 문자를 더함문자열의 인덱스는 0부터 시작하므로 i-1을 해줍니다.
  • i번째 문자를 추출하여 answer 문자열에 추가합니다.

python code

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

반응형

댓글