数据结构 4____计算时间复杂度
来源:互联网 发布:口袋妖怪手办淘宝 编辑:程序博客网 时间:2024/05/22 00:22
走台阶问题
走台阶版本1:
题目:一个台阶总共有n级,如果一次可以跳1级,也可以跳2级。求总共有多少总跳法,并分析算法的时间复杂度。
源自http://zhedahht.blog.163.com/blog/static/25411174200731844235261/
递归:f(n)=f(n-1)+f(n-2)
其中f(0)=f(1)=1;
对最后一步分情况讨论:
走一步为f(n-1)种方法,走两步为f(n-2)种方法。
算法复杂度:O(n)
或者采用斐波那契数列通项公式直接计算:F(n)=(√5/5)*{[(1+√5)/2]^n - [(1-√5)/2]^n}
走台阶版本2:
题目:一个台阶总共有n级,如果一次可以跳1-n级。求总共有多少总跳法,并分析算法的时间复杂度。
递归:f(n)=f(n-1)+f(n-2)+...+f(1)+f(0)=2*f(n-1)=2^(n-1)
对最后一步分情况讨论:
最后一步走i个台阶有f(n-i)种方法,所以
(1)f(n)=f(n-1)+f(n-2)+...+f(1)+f(0)
(2)f(n-1)=f(n-2)+f(n-3)+...+f(1)+f(0)
(1)-(2)得f(n)=2*f(n-1)
有因为f(1)=1, 所以f(n)=2^(n-1)
算法复杂度:O(1)
本文转载自: http://blog.csdn.net/abcjennifer/article/details/7589418
0 0
- 数据结构 4____计算时间复杂度
- 数据结构时间复杂度计算
- 数据结构与算法____时间复杂度和空间复杂度
- 数据结构时间复杂度的计算
- 数据结构时间复杂度的计算
- 数据结构时间复杂度的计算
- 数据结构-算法-时间复杂度计算
- 数据结构之计算时间复杂度
- 数据结构-算法-时间复杂度计算
- 1.1 数据结构-时间复杂度计算
- 数据结构-算法-时间复杂度计算
- 数据结构时间空间复杂度计算
- 【数据结构】根据主定理,计算时间复杂度
- 数据结构与算法-如何计算时间复杂度
- 数据结构::递归时间复杂度的计算
- 数据结构中的时间复杂度的计算
- 数据结构(2)--计算时间复杂度
- 数据结构 时间复杂度
- Appium——iOS自动化测试
- SQL Server 2012基本语句(带实例)
- systemctl开机启动wpa_supplicant
- iOS经典讲解之Objective-C属性的内存管理原理
- android Gallery模拟左右滑动的listView
- 数据结构 4____计算时间复杂度
- 使用GrabCut算法提取前景物体
- 使用php的swoole框架,实现高性能长连接websocket
- 在Windows7中如何创建删除特殊目录?
- m个生产者和n个消费者和x个搬运者的java实现
- LeetCode 题解(240) : Strobogrammatic Number III
- 联合体(union)
- CystalReport for VS 2013 中报表的显示问题
- python : import sqlite3 测试代码