笔记 1

数据结构主要研究组织大量数据的方法,算法分析则是对算法运行时间的评估。

用下列四个定义表示函数增长率的大小:

  1. 如果存在正常数 c 和 n0 使得当 N>=n0 时 T(N)<=cf(N), 则记为 T(N) = O(f(N)).
  1. 如果存在正常数 c 和 n0 使得当 N>=n0 时 T(N)>=cg(N), 则记为 T(N) = Ω(g(N)).
  2. T(N) = θ(h(N)) 当且仅当 T(N) = O(h(N)) 且 T(N) = Ω(h(N)).
  3. 如果 T(N) = O(p(N)) 且 T(N) ≠ θ(p(N)), 则 T(N) = o(p(N)).

例如,T(N) = 1000N, f(N) = N^2
用大 O 记法表述为:1000N = O(N^2)

即:

  1. T(N) 增长率小于等于 f(N).
  1. T(N) 增长率大于等于 g(N).
  2. T(N) 增长率等于 h(N).
  3. T(N) 增长率小于 p(N).

几个法则:
若 T1(N) = O(f(n)), T2(N) = O(g(n)), 则:

  1. T1(N) + T2(N) = max(O(f(N)), O(g(N)))
  2. T1(N) × T2(N) = O(f(N) × g(N)).

几个典型的函数增长率:

函数 名称
c 常数
logN 对数级
(logN)^2 对数平方
N 线性级
NlogN
N^2 平方级
N^3 立方级
2^N 指数级

PS: N 的增长率要快于 logN 的任意次幂。

运行时间计算

计算 3次幂之和 的示例代码:

int Sum(int N)
{
         int i, PartialSum;

/* 1 */  PartialSum = 0;
/* 2 */  for (int i=1; i<=N; i++)
/* 3 */    PartialSum += i * i * i;
/* 4 */  return PartialSum;
}

运行时间分析:

  1. 声明不计时间;
  2. 第 1 行和第 4 行各占一个时间单元;
  3. 第 3 行每执行一次占用 4 个时间单元(两次乘法,一次加法,一次赋值),而执行 N 次共占用 4N 个时间单元;
  4. 第 2 行在初始化 i, 测试 i<= N 和对 i 的自增运算中隐含着开销(初始化1个时间单元,所有的测试 N+1 个时间单元,以及所有的自增运算 N 个时间单元,共2N+2)。

我们忽略调用函数和返回值的开销,得到总量是6N+4,因此我们说该函数是 O(N).

计算运行时间的一般法则

  • for 循环
    一次 for 循环的运行时间至多是该 for 循环内语句(包括测试语句)的运行时间乘以迭代次数。

  • 嵌套的 for 循环
    从里向外分析。一组嵌套内部的一条语句总的运行时间为该语句的运行时间乘以该组所有的 for 循环的大小的乘积。例如:

for (i=0; i<N; i++)
    for (j=0; j<N; j++)
      k++;

该程序片段为 O(N^2).

  • 顺序语句
    将各个语句的运行时间求和即可(即,其中的最大值)。例如,下述程序片段先用去 O(N), 再花费 O(N^2), 总开销也是 O(N^2).
for (i=0; i<N; i++)
    a[i] = 0;
for (i=0; i<N; i++)
    for (j=0; j<N; j++)
      a[i] += a[j] + i + j;
  • if/else 语句
    对程序片段
if (condition)
    S1
else
    S2

一个 if/else 语句的运行时间不超过判断再加上 S1 和 S2 中运行时间长者的总运行时间。

《数据结构与算法分析》

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342

推荐阅读更多精彩内容

  • 个人学习批处理的初衷来源于实际工作;在某个迭代版本有个BS(安卓手游模拟器)大需求,从而在测试过程中就重复涉及到...
    Luckykailiu阅读 4,678评论 0 11
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,560评论 18 399
  • 从女孩到女人,这一辈子,得历经多少磨难呢?如果只是听了敦敦道理,就会变成自己希望的人生,那生命岂不是活在镜花水月一...
    许之欢喜阅读 876评论 1 2
  • 满足是头脑里的一种状态而不是头脑里装有满意的事件。满意的事件总是一种依赖,依赖就意味着有一天依恋的对象不再时,伴随...
    赫明华阅读 1,281评论 9 9
  • 霍元甲终其一生都在问一个问题,练武究竟为什么,为了平静自己心绪,控制自己身体。伟大的拳王说,心中没有了愤怒,你便成...
    闪闪惹人爱哦阅读 69评论 0 0