欢迎来到得力文库 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
得力文库 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    算法的复杂度.ppt

    • 资源ID:4153193       资源大小:44.50KB        全文页数:18页
    • 资源格式: PPT        下载积分:10金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要10金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    算法的复杂度.ppt

    算法的复杂度,二分查找算法的运行效率,影响二分查找算法的运行效率的因素:,二分查找算法的运行效率,影响二分查找算法的运行效率的因素: 输入规模 (在100个数中查找 vs 在106个数中查找) 硬件平台 (巨型计算机 vs PC机) 输入 (查找23 vs 查找62),二分查找算法的运行效率,影响二分查找算法的运行效率的因素: 输入规模 - 定义算法的复杂度为输入规模的函数 (在100个数中查找 vs 在106个数中查找) 硬件平台 - 渐进表达式 (巨型计算机 vs PC机) 输入 - 分别考虑最坏情况、平均情况、最好情况下算法的复杂度 (查找23 vs 查找62),问题的输入规模,定义算法的复杂度以输入规模为参数。例如, 在n个已排序的数中进行查找,binarySearch算法的复杂度为O(logn) 对n个数进行排序,mergeSort算法的复杂度为O(nlogn),以下算法判断一个数是否为质数,对于输入为n的数,其复杂度为O(n)。 primilityTesting(n) for i = 2 to n 1 if (n % i = 0) return false; return true; 但是,人们认为primilityTesting算法的复杂度远远高于合并排序算法。,算法复杂度的渐进表示,硬件平台影响程序的运行效率,成为比较不同程序效率高低的一个障碍。 通过用渐进符号对程序效率渐进表示,能够消除硬件平台对程序效率的影响。 我们主要学习下面的几个渐进符号 , O,o,算法复杂度的渐进表示,“”类似于“=”。直观上,它表示两个函数在同一个数量级上。 例如,2n2 + 3n - 0.5 = (n2)。 定义:f(n) = (g(n)表示存在c10,c20,n00使得,当nn0时,0 c1g(n) f(n) c2g(n)。 如果算法A的复杂度为(n2),算法B的复杂度为(n3)。对于规模足够大的问题,算法A的运行时间一定比算法B的运行时间短,与A、B各自的运行平台无关。,算法复杂度的渐进表示,“O”类似于“”。直观上,f(n) = O(g(n)表示f(n)的数量级小于等于g(n)的数量级。 例如,2n2 + 3n - 0.5 = O(n2),5n = O(n2) 定义:f(n) = O(g(n)表示存在c0,n00使得,当nn0时,0 f(n) cg(n)。,算法复杂度的渐进表示,“”类似于“”。直观上,f(n) = (g(n)表示f(n)的数量级大于等于g(n)的数量级。 例如,2n2 + 3n - 0.5 = (n2), 0.5n3 = (n2) 定义:f(n) = (g(n)表示存在c0,n00使得,当nn0时,0 cg(n) f(n)。,算法复杂度的渐进表示,“o”类似于“0,存在n00使得,当nn0时,0 f(n) < cg(n)。,算法复杂度的渐进表示,“”类似于“”。直观上,f(n) = (g(n)表示f(n)的数量级大于g(n)的数量级。 例如,0.5n3 = (n2) 定义:f(n) = (g(n)表示对任意c0,存在n00使得,当nn0时,0 cg(n) < f(n)。,一些常用的渐进等式,O(1) + O(f(n) = O(f(n) O(1)*O(f(n) = O(f(n) O(f(n) + O(g(n) = O(f(n) if g(n) = O(f(n) = O(g(n) if f(n) = O(g(n) O(logcn) = O(log2n) (c0, c1),常见复杂度排序,O(logn), O(n), O(nlogn), O(n2), O(2n),最坏情况下的复杂度,对于所有可能的规模为n的问题,算法的最长运行时间。 binarySearch算法最坏情况下的复杂度为O(logn)。,最好情况下的复杂度,对于所有可能的规模为n的问题,算法的最短运行时间。 binarySearch算法在最好情况下的复杂度为O(1)。,平均情况下的复杂度,对于所有可能的规模为n的问题,算法在平均情况下的运行时间。 以binarySearch为例,学习算法在平均情况下的复杂度。,平均情况下的复杂度,在查找成功的情况下,binarySearch的平均循环次数: (1/n)*1 + (2/n)*2 + (4/n)*3 + (8/n)*4 + + (2logn-1/n)*logn = = logn + (1/n)*logn 1 = O(logn) 因此,在查找成功的情况下,binarySearch的平均复杂度: O(logn)*O(1) = O(logn),

    注意事项

    本文(算法的复杂度.ppt)为本站会员(创****公)主动上传,得力文库 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知得力文库 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于得利文库 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

    © 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

    黑龙江省互联网违法和不良信息举报
    举报电话:0468-3380021 邮箱:hgswwxb@163.com  

    收起
    展开