tip:md中插表情,可用字符/符号的Unicode编码 比如😀😎🙅😱👽也可以替代一些icon,减少网页图片
斐波那契数列
题目描述
大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0)。
n<=39
1 | function Fibonacci(n) |
总结:
斐波那契数列的标准公式为:F(1)=1,F(2)=1, F(n)=F(n-1)+F(n-2)(n>=3,n∈N*)
跳台阶
题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法(先后次序不同算不同的结果)。
1 | function jumpFloor(number) |
总结:
这题其实与上一题一样:
🐸跳1阶,有1种情况;
🐸跳2阶,有2种情况;
🐸跳3阶,有3种情况;
🐸跳4阶,有5种情况;
可发现规律,其实就是斐波那契数列
f(n)=f(n-1)+f(n-2)
变态跳台阶
题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
1 | function jumpFloorII(number) |
总结:
n级台阶
跳1级,剩下n-1级,有f(n-1)种方法;
跳2级,剩下n-2,有f(n-2)种方法;
跳3级,剩下n-3,有f(n-3)种方法;
。。。
跳n-1级,剩下1级,有f(1)种方法;
总的方法相加:
f(n)=f(n-1)+f(n-2)+…+f(1)=2*f(n-1),找到规律
矩形覆盖
题目描述
我们可以用21的小矩形横着或者竖着去覆盖更大的矩形。请问用n个21的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法?
比如n=3时,2*3的矩形块有3种覆盖方法:
1 | function rectCover(number) |
总结:遇事不决就枚举,还是斐波那契数列