算法的时间复杂度
来源:互联网 发布:java运输管理系统代码 编辑:程序博客网 时间:2024/06/05 10:12
1,时间复杂度:T(n)=O(f(n)).它表示随问题规模n的增大,算法的执行时间的增长率和f(n)的增长率相同。在计算时间复杂度时,有两条规则:只保留高阶项;舍弃系数。下面举例说明具体该如何计算。
(1) 简单赋值语句:
{++x;s=0;}
{temp=i;i=j;j=temp;}上面这两个简单的语句,时间复杂度为:T(n)=O(1) 。即就是,如果算法的执行时间是一个与问题规模n 无关的常数,则算法的时间复杂度为常数阶,记为T(n)=O(1).
(2) 简单循环语句:
for(int i=1;i<=n;++i;) for(int j=1;j<=n;++j;) {c[i][j]=0;}第一句执行次数:1+n+n
第二句执行次数:n*(1+n+n)
第三句执行次数:n*n
则f(n)=3*n^2+3*n+1,保留高阶项,舍弃系数之后为f(n)=n^2,所以时间复杂度为T(n)=O(n^2).
分析结果,可以看出,对步进循环语句只需要考虑循环体语句执行的次数,而忽略该语句中步长加一、终止判别、循环转移等成分。当有若干个循环语句时,算法的时间复杂度是由嵌套层数最多的循环语句中最里层语句的频度决定的。
(3) 选择分支结构
if(x>n) x++;else for(int j=1;j<=n;j+=) x++;时间复杂度:T(n)=O(n)
2.递归时间复杂度
例1:
int Age(int n){if(n==1){return 10;}return Age(n-1)+2;}
时间复杂度:T(n)=O(n)
n,n-1,n-2,n-3,……0 ----->0,1,2,3,……n
例2:int Fun(int n){if(n<=1){return 1;}return Fun(n-2)+1;}
时间复杂度:T(n)=O(n)
n,n-2,n-4,n-6,……0 ----->0,2,4,6,……n
例3int Fun(int n){if(n<=1){return 1;}return Fun(n/2)+1;}时间复杂度:T(n)=O(log2n) (以2为底n的对数,不会编辑对数,见谅呀)
n,n/2,n/4,……1 ------>1,2,4,……n ----->2^x=n ----->x=以2为底n的对数
3.老师讲的考试题,很重要的!!!
题目1:(1)下面的程序是什么意思?(2) 时间复杂度是多少呢?
bool Fun(int n){int i=2;while (n%i!=0&&i*1.0<sqrt(n)) i++;if(i*1.0>sqrt(n))return true;elsereturn false;}这个程序是用来判断素数。时间复杂度为O(n^(1/2))
题目2(疑问?)
for (int i=1;i<=n;++i) for (int j=1;j<=n;j+=i) return +=(i+j);A.O(n) B.(nlogn) C O(n的1.5次幂) D O (n的2 次幂)
for (int j=1;j<=n;j+=i)由这一句推出F(n)=n+n/2+n/3+n/4+……n/n
阅读全文
0 0
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- 算法的时间复杂度
- JS转义特殊字符
- 批处理一 入门命令
- 资源文件路径详解(getResource)
- 《Greenplum5.0 最佳实践 》SQL 转换
- 【重磅】AlphaZero炼成最强通用棋类AI,DeepMind强化学习算法8小时完爆人类棋类游戏
- 算法的时间复杂度
- CentOS7 配置 VPN
- Android中的缓存概述
- eclipse idea 快捷键对比
- python中导入其他目录下的模块
- ionic3在ios上顶部导航栏显示不正常--据顶部有空隙条
- Caused by: java.lang.ClassNotFoundException: javax.el.ELManager
- windows 批量删除nginx 进程
- 二叉树 红黑树的理解