문자열 my_string과 두 정수 m, c가 주어집니다. my_string을 한 줄에 m 글자씩 가로로 적었을 때 왼쪽부터 세로로 c번째 열에 적힌 글자들을 문자열로 return 하는 solution 함수를 작성해 주세요.
my_string은 영소문자로 이루어져 있습니다.m ≤ my_string의 길이 ≤ 1,000m은 my_string 길이의 약수로만 주어집니다.c ≤ m| my_string | m | c | result |
|---|---|---|---|
| "ihrhbakrfpndopljhygc" | 4 | 2 | "happy" |
| "programmers" | 1 | 1 | "programmers" |
입출력 예 #1
예제 1번의 my_string을 한 줄에 4 글자씩 쓰면 다음의 표와 같습니다.
| 1열 | 2열 | 3열 | 4열 |
|---|---|---|---|
| i | h | r | h |
| b | a | k | r |
| f | p | n | d |
| o | p | l | j |
| h | y | g | c |
2열에 적힌 글자를 세로로 읽으면 happy이므로 "happy"를 return 합니다.
입출력 예 #2
my_string은 m이 1이므로 세로로 "programmers"를 적는 것과 같고 따라서 1열에 적힌 글자를 세로로 읽으면 programmers입니다. 따라서 "programmers"를 return 합니다.function solution(my_string, m, c) {
return [...my_string].filter((a,i)=> (i-(c-1))% m == 0 ).join('');
}
잘보면 배수 구하는 문제가 많다. 배수로 해결할수 있는지 생각해보자.
다른풀이
const solution=(s,m,c)=>s.match(new RegExp(`.{${m}}`,'g')).map(v=>v[c-1]).join('')
function solution(my_string, m, c) {
let answer ="";
for(let i = c-1; i < my_string.length ; i+=m) answer+=my_string[i];
return answer;
}