下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、如何判断程序的复杂程度:时间和空间复杂度时间复杂度:使用大O表示法来表示程序的时间复杂度常见的7种时间复杂度(复杂度由低到高排序)0(1):常数时间复杂度O(log(n):对数时间复杂度O(n):线性时间复杂度0(nA2):平方时间复杂度0(nA3):立方时间复杂度0(n):指数时间复杂度,k表示常数0(n!):阶乘时间复杂度ps:这里我们并不考虑前边的系数;0(1)并不表示复杂度为1,也可以是2、3等常数;0(n)表示程序运行了n次或者2n、3n次;以此类推其他时间复杂度时间复杂度的判断,以一段代码的最高复杂度为准;如何判断一段代码的时间复杂度简而言之就是看内部某段代码的执行次数0(1):常
2、数复杂度intn=1;System.out.println(n);12intn=1;System.out.println(n);System.out.println(n+1)System.out.println(n+2)12340(n):线性时间复杂度for(intj=0;jn;j+)System.out.println(j);123for(inti=0;in;i+)System.out.println(i);for(intj=0;jn;j+)System.out.println(j);1234560(nA2):平方时间复杂度for(inti=0;in;i+)for(intj=0;jn;j+)
3、System.out.println(i+j);12345O(nA3):立方时间复杂度for(inti=0;in;i+)for(intj=0;jn;j+)for(intk=0;kn;k+)System.out.println(i+j);1234567O(log(n):对数时间复杂度这里演示的是以2为底n的对数for(inti=0;in;i=i*2)System.out.println(i);1230(2切):指数时间复杂度/*递归求斐波那契数列的第n项;可以通过画运行树的方式获得时间复杂度*/intfib(intn)if(n2)returnn;returnfib(n-1)+fib(n-2);1
4、234567O(n!):阶乘时间复杂度todo小练习1:求和计算1n的和O(n)inty=2;for(inti=0;in;i+)y+=i;1234O(1)使用了求和公式:sum=n(n+1)/2inty=2;for(inti=0;in;i+)y+=i;1234小练习2:求斐波那契数列O(2An):intfib(intn)if(n2)returnn;returnfib(n-1)+fib(n-2);1234O(n):该方法比递归要快得多intfib2(intn)if(n=1|n=2)return1;inta=1,b=1,result=0;for(inti=3;i=n;i+)result=a+b;a
5、=b;b=result;returnresult;123456789101112主定理主定理(英语:mastertheorem)提供了用渐近符号(大O符号)表示许多由分治法得到的递推关系式的方法常用算法中的应用算法递回关系式运算时间二分搜寻算法二叉树遍历最佳排序矩阵搜索(已排好序的二维矩阵)合并排序所有排序的最优算法都是O(nlog(n)空间复杂度如何判断一段代码的空间复杂度主要通过两部分进行判断:数组的长度如果代码中应用了数组,那么数组的长度,基本上就是空间复杂度;e:维数组的空间复杂度是O(n);二维数组的空间复杂度是O(n)递归的深度如果代码中有递归,那么递归的深度,就是代码的空间复杂度的最大值ps:如果代码中既有数组,又有递归,那么两者的最大值就是代码的空间复杂度leecode有个爬楼梯的复杂度分析情况;可以进行练习数组和链表的时间复杂度分析数组随机增加:O(n)随机查询:O(1)随机删除:O(n)链表随机增加:O(1)随机查询:O(n)随机删除:O(1)跳表跳跃表(skiplist)是一种随机化的数据,由WilliamPugh在论文Skiplists:aprobabilisticalternativetobalancedtrees中提出,跳跃表以有序的方式在层次化的链表中保存元素,效率
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 饮用水卫生安全巡查工作制度
- 2024-2025学年度咨询工程师考前冲刺练习题附参考答案详解(轻巧夺冠)
- 2024-2025学年度法律职业资格考试预测复习及完整答案详解(全优)
- 2024-2025学年度监理工程师模拟试题【能力提升】附答案详解
- 2024-2025学年度医师定期考核题库检测试题打印完整附答案详解
- 2024-2025学年度法律硕士考试历年机考真题集含完整答案详解【夺冠】
- 2024-2025学年度医疗卫生系统人员题库附答案详解(典型题)
- 2024-2025学年全国统考教师资格考试《教育教学知识与能力(小学)》测试卷及参考答案详解【达标题】
- 2024-2025学年度辅警招聘考试考试综合练习附答案详解(B卷)
- 探讨学习方法的议论文4篇
- 安全复工复产培训题库及答案解析
- 新能源汽车维修技能实操考核题
- 《电子技术基础(第6版)》技工中职全套教学课件
- 2025年下半年中学教资笔试真题+参考答案(科目一+科目二)
- 工贸企业的安全培训课件
- 青春期男生生理卫生课件
- 水利水电工程设计信息模型分类和编码标准
- 压力管道设计审批人员考核试题及答案1
- 变电运行安全培训课件
- 中山北路第一小学创新课程开发与实施
- 血管外科基础用药
评论
0/150
提交评论