1. 使用动态规划递推法
2. 时间复杂度为O(n)
3. 不使用递归, 递归的时间复杂度为O(2^n) 指数级复杂度
function fibonacci(n) {
    if (n < 1) throw new Error('n is not greater than 0');
    if (n == 1 || n == 2) return 1;
    let a = new Array(n);
    a[0] = 1;
    a[1] = 1;
    for (let i = 2; i < n; i++) {
        a[i] = a[i - 1] + a[i - 2];
    }
    return a[n - 1];
}