반응형
암호 해독
문제 설명
군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.
암호화된 문자열 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
반응형
'algorithm' 카테고리의 다른 글
[프로그래머스]문자열 정렬하기 (1) - java, python (0) | 2023.03.03 |
---|---|
[프로그래머스]중복된 숫자 개수 - java, python (0) | 2023.03.03 |
[프로그래머스]문자열을 정수로 바꾸기 - java, python (0) | 2023.02.28 |
[프로그래머스]문자 반복 출력하기 - java, python (0) | 2023.02.23 |
[프로그래머스]x만큼 간격이 있는 n개의 숫자 - java, python (0) | 2023.02.23 |
댓글