算法时间空间复杂度

这篇具有很好参考价值的文章主要介绍了算法时间空间复杂度。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

算法

算法特性

1.有穷性:执行有穷步(有限步)之后结束。

2.确定性:只有唯一的执行路径。

3.可行性:代码可以执行起来。

4、输入:零个或多个输入。

5.输出:一个或多个输出。

时间效率和空间效率有时候是有矛盾的

时间复杂度

时间复杂度概念

概念: 若有某个辅助函数 f ( n ) \color{pink}{f(n)} f(n) 使得当n趋近于无穷大时。 T ( n ) / f ( n ) \color{pink}{T(n)/f(n)} T(n)/f(n)的极值为不等于0的常数,则称 f n 是 T ( n ) \color{pink}{fn是T(n)} fnT(n)的同数量级函数。记作 T ( n ) = O ( f ( n ) ) \color{pink}{T(n)=O(f(n))} T(n)=O(f(n)) O ( f ( n ) ) \color{pink}{O(f(n))} O(f(n))为算法的渐进时间复杂度(O是数量级的符号)

  时间复杂度是由嵌套最深层语句的频度决定的。

算法运行时间

算法运行时间=(每条语句频度 * 该语句执行一次所需的时间)的求和。

例如

i=1;
while(i<=n)
	i=i*2;

解释:

执行循环次数
1 i=1*2=21
2 i=2*2=22
3 i=2*2 *2=23
x i=2x
i<=n
则
2^x<=n
则
x<=log2(n)

时间复杂度分三种

(1):最坏时间复杂度

(2):平均时间复杂度

(3):最好时间复杂度

以上三种复杂度,通常考虑最坏时间复杂度

空间复杂度

   顾名思义: \color{pink}{顾名思义:} 顾名思义:算法所需存储空间的度量。 S ( n ) = O ( f ( n ) ) \color{pink}{S(n)=O(f(n))} S(n)=O(f(n))

算法时间空间复杂度

学的不是技术,更是梦想!!!文章来源地址https://www.toymoban.com/news/detail-442952.html

到了这里,关于算法时间空间复杂度的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 算法学习22:时间复杂度 和 空间复杂度

    提示:以下是本篇文章正文内容: 😍😍😍文章链接👍👍👍 提示:这里对文章进行总结: 💕💕💕

    2024年04月22日
    浏览(63)
  • 算法的时间复杂度、空间复杂度如何比较?

    目录 一、时间复杂度BigO 大O的渐进表示法: 例题一: 例题2: 例题3:冒泡排序的时间复杂度 例题4:二分查找的时间复杂度 书写对数的讲究: 例题5:  实例6: 利用时间复杂度解决编程题 ​编辑思路一: 思路二: 源码: 思路三: 回顾位操作符 二、空间复杂度详解 概念

    2024年02月15日
    浏览(60)
  • 如何衡量算法的效率?时间复杂度&&空间复杂度

    本篇博客会讲解如何衡量一个算法的效率。衡量算法的效率,主要有2个维度,分别是:时间复杂度和空间复杂度。 时间复杂度用来衡量算法的时间效率。时间复杂度越低,算法的耗时越短,效率则越高。 空间复杂度用来衡量算法的空间效率。空间复杂度越低,算法占用的空

    2023年04月20日
    浏览(29)
  • 算法时间空间复杂度

    1. 有穷性 :执行有穷步(有限步)之后结束。 2. 确定性 :只有唯一的执行路径。 3. 可行性 :代码可以执行起来。 4、 输入 :零个或多个输入。 5. 输出 :一个或多个输出。 时间效率和空间效率有时候是有矛盾的 概念: 若有某个辅助函数 f ( n ) color{pink}{f(n)} f ( n ) 使得当

    2024年02月04日
    浏览(47)
  • 八大排序算法(含时间复杂度、空间复杂度、算法稳定性)

    下列算法默认都是对数组进行升序 1.1、算法思想 插入排序是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。 插入排序的具体步骤如下: 从第一个元素开始,该元素可以认为已经被排序;

    2024年02月08日
    浏览(36)
  • 算法的特性和空间复杂度---数据结构

      目录 前言: 1.算法 1.1算法的特性 1.2设计算法 2.空间复杂度 3.学习复杂度的意义 ❤博主CSDN:啊苏要学习     ▶专栏分类:数据结构◀   学习数据结构是一件有趣的事情,希望读者能在我的博文切实感受到数据之间存在的关系,在对数据元素进行操作的时候,能心中有数,

    2024年02月06日
    浏览(28)
  • 数据结构与算法-时间复杂度与空间复杂度

    数据结构是计算机存储、组织数据的方式,指相互之间存在一种或多种特定关系的数据元素的集合。 算法就是定义良好的计算过程,他取一个或一组的值为输入,并产生一个或一组值作为输出。简单来说算法就是一系列的计算步骤,用来将输入数据转化成输出结果。 算法在

    2024年02月07日
    浏览(34)
  • 数据结构--算法的时间复杂度和空间复杂度

    算法效率是指 算法在计算机上运行时所消耗的时间和资源 。这是衡量算法执行速度和资源利用情况的重要指标。 例子: 这是一个斐波那契函数,用的是递归的计算方法,每次创建函数就会在栈区开辟一块空间,递归次数越多,开辟空间越多; 所以, 代码的简洁说明不了算

    2024年02月15日
    浏览(31)
  • 【数据结构和算法】时间复杂度和空间复杂度

    目录   一、前言 二、时间复杂度 2.1时间复杂度表示形式 2.1.1规则: 3.1如何计算时间复杂度 3.1.1线性阶 3.1.2平方阶 3.1.3对数阶 常见的时间复杂度排序: 三、空间复杂度 3.1Java的基本类型内存占用 数据结构和算法是程序的灵魂,这是某位程序员大佬所言,学习了这门,我们便可

    2023年04月09日
    浏览(32)
  • 算法的时间复杂度和空间复杂度(数据结构)

    目录 1、算法效率 1如何衡量一个算法的好坏 2算法的复杂度 2、时间复杂度 1时间复杂度的概念 2大O的渐进表示法 2时间复杂度计算例题 1、计算Func2的时间复杂度 2、计算Func3的时间复杂度 3、计算Func4的时间复杂度 4、计算strchr的时间复杂度 5、计算BubbleSort的时间复杂度 6、计算

    2024年02月03日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包