📕 문제 설명
군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.
- 암호화된 문자열 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합니다.
😊 나의 답변
function solution(cipher, code) {
var answer = [];
for(var i=0; i<=cipher.length; i++){
if(i%code==0){
answer.push(cipher[i-1])
}
}
return answer.join("")
}
2023년 1월의 나의 답변
var 쓴 거 맘에 안들고, 뭔가 복잡한 느낌이라 다시 풀어보았다
function solution(cipher, code) {
return [...cipher].filter((_, i) => (i + 1) % code === 0).join('');
}
배열 메서드 filter()
를 활용해 code의 배수인 index의 값만 남은 배열로 만들고, join('')
하여 문자열로 반환해주었다.
이제 문제를 보면 어떤 메서드를 사용하면 좋을지 떠오르는 게 신기하고 재밌고 뿌듯하다 😊
728x90
반응형
'프로그래머스 > Lv. 0 코딩테스트 입문' 카테고리의 다른 글
[프로그래머스] Lv.0 369게임 / JS (0) | 2023.08.14 |
---|---|
[프로그래머스] Lv.0 가까운 수 / JS (0) | 2023.08.14 |
[프로그래머스] Lv.0 대문자와 소문자 / JS (0) | 2023.08.11 |
[프로그래머스] Lv.0 인덱스 바꾸기 / JS (0) | 2023.08.11 |
[프로그래머스] Lv.0 한 번만 등장한 문자 / JS (0) | 2023.08.11 |