- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
算法及其
时间复杂度
1
有关基本概念:问题
问题及实例
• 问题
需要回答的一般性提问,通常含若干参数
• 问题描述
定义问题参数(集合,变量,函数,序列等)
说明每个参数的取值范围及参数间的关系
定义问题的解
说明解满足的条件(优化目标或约束条件)
• 问题实例
参数的一组赋值可得到问题的一个实例
2
算法
• 算法
有限条指令的序列
这个指令序列确定了解决某个问题的一
系列运算或操作
• 算法A 解问题P
把问题P 的任何实例作为算法A 的输入
每步计算是确定性的
A 能够在有限步停机
输出该实例的正确的解
3
基本运算与输入规模
• 算法时间复杂度: 针对指定基本运算,计
数算法所做运算次数
• 基本运算: 比较, 加法, 乘法, 置指针, 交换…
• 输入规模:输入串编码长度
通常用下述参数度量:数组元素多少,调
度问题的任务个数,图的顶点数与边数等.
• 算法基本运算次数可表为输入规模的函数
• 给定问题和基本运算就决定了一个算法类
4
输入规模
• 排序:数组中元素个数n
• 检索:被检索数组的元素个数n
• 整数乘法:两个整数的位数m, n
• 矩阵相乘:矩阵的行列数i, j, k
• 图的遍历:图的顶点数n, 边数m
…
5
基本运算
• 排序: 元素之间的比较
• 检索: 被检索元素x 与数组元素的比较
• 整数乘法: 每位数字相乘(位乘) 1 次
m位和n位整数相乘要做mn次位乘
• 矩阵相乘: 每对元素乘1 次
i×j 矩阵与j ×k 矩阵相乘要做ijk 次乘法
• 图的遍历: 置指针
...
6
算法的两种时间复杂度
对于相同输入规模的不同实例,算法的基本
运算次数也不一样,可定义两种时间复杂度
最坏情况下的时间复杂度W(n)
算法求解输入规模为n 的实例所需要的最长
时间
平均情况下的时间复杂度A (n)
在给定同样规模为n 的输入实例的概率分布
下,算法求解这些实例所需要的平均时间
7
A (n) 计算公式
平均情况下的时间复杂度A (n)
设S 是规模为n 的实例集
实例I ∈S 的概率是PI
算法对实例I 执行的基本运算次数是tI
A(n) ∑P t
I I
I ∈S
在某些情况下可以假定每个输入实例概
率相等
文档评论(0)