[프로그래머스] 암호 해독

당당·2023년 4월 20일
0

프로그래머스

목록 보기
9/245

https://school.programmers.co.kr/learn/courses/30/lessons/120892

📔문제

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

  • 암호화된 문자열 cipher를 주고받습니다.
  • 그 문자열에서 code의 배수 번째 글자만 진짜 암호입니다.

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


🚫제한사항

1 ≤ cipher의 길이 ≤ 1,000
1 ≤ code ≤ cipher의 길이
cipher는 소문자와 공백으로만 구성되어 있습니다.
공백도 하나의 문자로 취급합니다.


📝입출력 예

ciphercoderesult
"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합니다.


🧮알고리즘 분류

  • 조건문
  • 반복문
  • 시뮬레이션
  • 문자열

📃소스 코드

class Solution {
    public String solution(String cipher, int code) {
        String answer = "";
        int count=2;
        
        for(int i=code;i<=cipher.length();i++){
            answer=answer+cipher.charAt(i-1);
            i=count*code-1;
            count++;
        }
        
        return answer;
    }
}

📰출력 결과


📂고찰

code의 배수만큼 i의 값을 조정해줬다.
그리고 첫 글자를 1부터 계산하기 때문에 cipher.length()만큼 반복이 되어야 마지막 문자도 출력이 되었다.

i의 값을 count*code-1 로 준 이유는 i는 반복문 시작에 i++ 이 되기 때문이다.
count는 배수를 위한 변수이다.

profile
MySQL DBA 신입 지원

0개의 댓글