前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Python Algorithms - C3 Counting 101

Python Algorithms - C3 Counting 101

作者头像
宅男潇涧
发布2018-08-01 15:48:48
4610
发布2018-08-01 15:48:48
举报
文章被收录于专栏:潇涧技术专栏

Python算法设计篇(3) Chapter 3: Counting 101

The greatest shortcoming of the human race is our inability to understand the exponential function. —— Dr. Albert A. Bartlett, World Population Balance Board of Advisors

原书主要介绍了一些基础数学,例如排列组合以及递归循环等,但是本节只重点介绍计算算法的运行时间的三种方法

因为本节内容都很简单,所以我只是浏览了一下,重要的只有计算算法的运行时间的三种方法: 1.代换法; 2.递归树法; 3.主定理法。

1.代换法

代换法一般是先猜测解的形式,然后用数学归纳法来证明它

下面是算法导论中的一个求解例子

image
image

有意思的是,还有一类问题可以通过变量替换变成容易求解的形式

image
image

下面是常用的一些递归式以及它们对应的结果还有实际算法实例

image
image

2.递归树法

这种方法就是通过画递归树,然后对每层进行求和,最后将每层的结果相加得到对总的算法运行时间的估计

image
image

3.主定理法

这种方法大家最喜欢,给出了一种就像是公式一样的结论,虽然它没有覆盖所有的情况,而且证明非常复杂,但是很多情况下都是可以直接使用的,还有,需要注意主定理在不同情况下的条件,尤其是多项式大于和多项式小于!

image
image

不喜欢本节的可以跳过,不留练习了这次,嘿嘿,想练习的话刷算法导论的题目吧

返回Python数据结构与算法设计篇目录

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2014/7/1,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档