암호 해독
문제 설명
군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.
- 암호화된 문자열 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합니다.
제출
import Foundation
func solution(_ cipher:String, _ code:Int) -> String {
let cipher = cipher.map{String($0)}
var answer = ""
for i in stride(from: code, through: cipher.count, by: code){
answer += cipher[i-1]
}
return answer
}
입력받은 문자열을 map 함수를 사용해 String형 배열로 변환한다.
for문을 stride 함수를 사용해 입력받은 code부터 배열의 개수까지 code 크기만큼 i를 증가시키면서 반복하면서 배열의 i-1 번째 요소를 answer에 추가한다.
반응형
'📖 Coding Test > Programmers LV.0' 카테고리의 다른 글
[프로그래머스 LV.0] 영어가 싫어요 (0) | 2023.01.10 |
---|---|
[프로그래머스 LV.0] 대문자와 소문자 (0) | 2023.01.09 |
[프로그래머스 LV.0] 369게임 (0) | 2023.01.09 |
[프로그래머스 LV.0] 가까운 수 (0) | 2023.01.09 |
[프로그래머스 LV.0] 삼각형의 완성조건 (1) (0) | 2023.01.07 |
댓글