Just Do IT!
[프로그래머스 Level 0] 120892. 암호 해독 (JavaScript) 본문
728x90
문제 설명
군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.
- 암호화된 문자열 cipher를 주고받습니다.
- 그 문자열에서 code의 배수 번째 글자만 진짜 암호입니다.
문자열 cipher와 정수 code가 매개변수로 주어질 때 해독된 암호 문자열을 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤ cipher의 길이 ≤ 1,000
- 1 ≤ code ≤ cipher의 길이
- cipher는 소문자와 공백으로만 구성되어 있습니다.
- 공백도 하나의 문자로 취급합니다.
입출력 예
ciper | 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) {
// code의 배수번째 글자만 진짜 암호
// 1. code의 배수 계산
// => cipher 전체를 배열로 바꿔서 순서 계산해보기
// 2. cipher 중에 배수번째만 골라오기
// 3. 골라온 글짜를 새로운 배열에 담기
// 4. return 새로운 배열
let cipher_arr = [...cipher];
let new_arr = [];
cipher_arr.forEach((n, i) => {
if ((i + 1) % code === 0) {
new_arr.push(cipher_arr[i])
}
})
return new_arr.join("")
}
다른 방법으로 풀기 (굳이 배열로 풀지 않아도 된다)
function solution(cipher, code) {
var answer = "";
for (let i = code - 1; i < cipher.length; i += code) {
answer += cipher[i];
}
return answer;
}
728x90
'코딩테스트 준비 > 프로그래머스' 카테고리의 다른 글
[프로그래머스 Level 0] 120899. 가장 큰 수 찾기 (JavaScript) (0) | 2023.01.03 |
---|---|
[프로그래머스 level 0] 120839. 가위 바위 보 (JavaScript) (0) | 2023.01.02 |
[프로그래머스 Level 0] 120893. 대문자와 소문자 (JavaScript) (0) | 2022.12.29 |
[프로그래머스 Level 0] 120845. 주사위의 개수 (JavaScript) (0) | 2022.12.21 |
[프로그래머스 Level 0] 120850. 문자열 정렬하기 (1) (JavaScript) (0) | 2022.12.20 |