세로 길이 2, 가로 길이 n인 2 x n 보드가 있습니다. 2 x 1 크기의 타일을 가지고 이 보드를 채우는 모든 경우의 수를 리턴해야 합니다.
number 타입의 1 이상의 자연수
number 타입을 리턴해야 합니다.
타일을 가로, 세로 어느 방향으로 놓아도 상관없습니다. (입출력 예시 참고)
let output = tiling(2);
console.log(output); // --> 2
output = tiling(4);
console.log(output); // --> 5
/*
2 x 4 보드에 타일을 놓는 방법은 5가지
각 타일을 a, b, c, d로 구분
2 | a b c d
1 | a b c d
2 | a a c c
1 | b b d d
2 | a b c c
1 | a b d d
2 | a a c d
1 | b b c d
2 | a b b d
1 | a c c d
*/
타일링 문제를 해결하는 효율적인 알고리즘(O(N))이 존재합니다. 반드시 직접 문제를 해결하시면서 입력의 크기에 따라 어떻게 달라지는지 혹은 어떻게 반복되는지 관찰하시기 바랍니다.
let tiling = function (n) {
const result = [0, 1, 2];
for (let i = 3; i <= n; i++) {
result[i] = result[i-1] + result[i-2];
}
return result[n]
}
let tiling = function (n) {
// TODO: 여기에 코드를 작성합니다.
// 재귀로 풀 수 있음
// 세로를 m, 가로를 n이라고 놓고
// function(n) = function(n-2) + function(n-1) => 이것을 최적화기법으로 업그레이드 해야함
// Memoization 필요
const save = [0, 1, 2];
const subTiling = (size) => {
if(save[size] !== undefined) return save[size]; // 이미 해결한 문제는 풀지 않음. 이 줄을 쓰지 않으면 시간초과가 생겨버림
if(size <= 2) return save[size];
save[size] = subTiling(size-1) + subTiling(size-2);
return save[size];
}
return subTiling(n);
};