code/[프로그래머스] python
[코딩 테스트 연습 입문] 암호 해독
오리는짹짹
2022. 12. 27. 11:48
문제
군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.
- 암호화된 문자열 cipher를 주고받습니다.
- 그 문자열에서 code의 배수 번째 글자만 진짜 암호입니다.
문자열 cipher와 정수 code가 매개변수로 주어질 때 해독된 암호 문자열을 return하도록 solution 함수를 완성해주세요.
❗제한사항❗
- 1 ≤ cipher의 길이 ≤ 1,000
- 1 ≤ code ≤ cipher의 길이
- cipher는 소문자와 공백으로만 구성되어 있습니다.
- 공백도 하나의 문자로 취급합니다.
입출력 예
입출력 예 설명
입출력 예 #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 zzin in range(code-1,len(cipher),code):
answer+=cipher[zzin]
return answer
📝설명
for문을 너무 사랑하는 나..^^
cipher에서는 code의 배수 번째 글자만 빼내야 암호를 해독할 수 있다.
시작이 code번째여야 하는데, 실제로 인덱스는 0부터 시작하기 때문에 반복범위를 code-1로 시작하도록 한다.
길이를 재고, code의 주기를 두고 반복하도록 한다.
그렇게 나온 zzin은 answer에 더하면 끝!
👑모범 답안
🔎일부 항목을 가져올 수 있도록, [i_start, i_end:i_step]을 사용한다.
그러면 훨씬 더 간결한 코드를 짤 수 있다.
👀느낀 점
: 나는 for문 중복이다.
하지만 어떤 상황에서는 for문보다 더 간결하게 사용할 수 있는 [i_start, i_end:i_step]이 있다는 걸 잊지 말아야 한다.
내세상만에서 흥선대원군이 되지 말아야 한다.......