[프로그래머스] 암호해독
카테고리 : 컴퓨터 공학
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 암호해독 · js 암호해독
태그: programmers · Code Refactoring · 참고 할 만한 다른 사람의 코드 · 코딩 기초 트레이닝 · 프로그래머스 · 코딩테스트 연습 · JavaScript · 암호해독 · js 암호해독
문제 설명
군 전략가 머쓱이는 전쟁 중 적군이 다음과 같은 암호 체계를 사용한다는 것을 알아냈습니다.
- 암호화된 문자열
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 = [...cipher].reduce(
(a, c, i) => ((i + 1) % code === 0 ? a + c : a),
""
);
return answer;
}
나의 두번째 풀이(Code Refactoring)
function solution(cipher, code) {
let result = "";
for (i = code - 1; i < cipher.length; i += code) {
result += cipher[i];
}
return result;
}
// 인덱스는 0부터 시작하니 code의 인덱스값의 -1 값을 추출한다 i는 code의 숫자만큼 출력
// result에 i번째에 해당하는 값을 result에 담아준다
참고 할 만한 다른 사람의 코드
function solution(cipher, code) {
return cipher
.split("")
.filter((_, index) => (index + 1) % code === 0)
.join("");
}
//filter의 인덱스값을 code 값에 해당하는 문자열 추출 방법