๋ฌธ์ )
Given a multi-dimensional array arr and a depth n, return a flattened version of that array.
A multi-dimensional array is a recursive data structure that contains integers or other multi-dimensional arrays.
A flattened array is a version of that array with some or all of the sub-arrays removed and replaced with the actual elements in that sub-array. This flattening operation should only be done if the current depth of nesting is less than n. The depth of the elements in the first array are considered to be 0.
Please solve it without the built-in Array.flat method.
- ์์ฝํด๋ณด์๋ฉด ๋ค์ฐจ์๋ฐฐ์ด arr๊ณผ ๊น์ด n์ด ์ฃผ์ด์ง ๋, ํํํ๋ ๋ฒ์ ผ์ ๋ฐํํ๋ผ.
- ๋ค์ฐจ์ ๋ฐฐ์ด์ ์ ์ ๋๋ ๋ค๋ฅธ ๋ค์ฐจ์ ๋ฐฐ์ด์ ํฌํจํ๋ ์ฌ๊ท์ ์ธ ๋ฐ์ดํฐ ๊ตฌ์กฐ๋ฅผ ๊ฐ์ง๊ณ ์๋ค.
- ์ด ํํํ ์์ ์ ํ์ฌ ์ค์ฒฉ๊น์ด๊ฐ n๋ณด๋ค ์์ ๋๋ง ์ํ๋์ด์ผํ๋ค.
- ๋ด์ฅ๋ 'Array.flat' ๋ฉ์๋ ์์ด ๋ฌธ์ ํด๊ฒฐํ์์ค
ํด๊ฒฐ์ฝ๋)
var flat = function (arr, n) {
if (n === 0) {
return arr;
}
let answer = [];
arr.forEach(element => {
if (n > 0 && Array.isArray(element)) {
answer.push(...flat(element, n - 1));
} else {
answer.push(element);
}
});
return answer;
};
์ฐ์ ์ ์ผ๋ก n์ด 0 ์ผ ๋ ๊ฒฝ์ฐ์ ์๋ฅผ ๊ตฌํ๊ณ
์ดํ์๋ arr์ ๋๋ฉด์ isArray ๋ฉ์๋๋ก ๋ฐ์ดํฐ๊ฐ ์ ์์ธ์ง ๋ฐฐ์ด์ธ์ง ์ฒดํนํ๋ค. ๋ฐฐ์ด์ด๋ฉด ๊ทธ๊ฑธ ๋ค์ ๋๊ฐ์ด flat ์ฌ๊ทํจ์ ์ ์ฉ
- isArray(obj) : ํ๋ผ๋ฏธํฐ๋ก ๋ฐ์ ๊ฐ์ด ๋ฐฐ์ด์ธ์ง ์๋์ง ์ฒดํนํ๋ ๋ฉ์๋
๋ค์ฐจ์๋ฐฐ์ด์ด ๋ค์ด๊ฐ๋ ์๊ฐ ๋จธ๋ฆฟ์์ด ๋ตํด์ง.....
'๊ฐ๋ฐ > ๐ฌ ์ฝ๋ฉํ ์คํธ' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[leetCode] 34. Find First and Last Position of Element in Sorted Array - Javascript (0) | 2023.11.10 |
---|---|
[leetCode/์ฝํ ๊ณต๋ถ] 2721. Execute Asynchronous Functions in Parallel (0) | 2023.08.22 |
[์๊ณ ๋ฆฌ์ฆ] .val ๊ณผ .next ์ ๋ป์? (0) | 2022.12.30 |
[codewars] Valid Parentheses (0) | 2022.03.30 |
[ํ๋ก๊ทธ๋๋จธ์ค] ์์ฅ - ์๋ฐ์คํฌ๋ฆฝํธ (0) | 2022.03.18 |