【数据结构】算法复杂度

数据结构

数据结构:是计算机存储和组织数据的方式。
比如打开一个网页,我们看到的文字就是数据,这些数据需要用一个结构来把他管理起来,我们称之为:数据结构

算法

就是定义一系列的计算步骤,用来将输入的数据转换成输出结果。

算法编写成可执行程序后,运行时会产生时间与空间的消耗,衡量一个算法的好坏就是从时间和空间两个维度来衡量的。

复杂度

如何衡量一个算法的好坏:

  • 看算法的时间复杂度
  • 看算法的空间复杂度(在计算机发展早期,内存空间有限,所以十分在意空间复杂度,但随着计算机的发展,到现在,已经不用担心计算机的内存空间问题了)

大o渐进表示法

在这里插入图片描述

时间复杂度
(衡量程序的效率)
定义:在计算机科学中,时间复杂度是一个函数式T(N)。
时间复杂度不能给出一个确切的时间,因为时间复杂度受到:

  • 编译环境和机器配置的影响
  • 并且时间只能程序写好后测试,不能写程序前通过理论计算评估
    在这里插入图片描述
    比如这是在vs debug下运行得出的时间

在这里插入图片描述
这是在vs release下运行得出的时间。(clock函数包含在time.h头文件下)

来个例子,理解一下:
在这里插入图片描述
计算Func2的时间复杂度,
在这里插入图片描述
再来一个例子巩固一下:
在这里插入图片描述
在这里插入图片描述

时间复杂度存在最好的情况、最坏的情况和平均情况,大o渐进表示法在实际中一半情况关注的是时间复杂度最坏的情况。
在这里插入图片描述

计算下列这段代码的时间复杂度

void func5(int n)
{
int cnt = 1;
while (cnt < n)
	{
	cnt *= 2;
	}
}

(取的都是最坏的情况)
在这里插入图片描述
指对互化那一步,需要注意一下,当n接近无穷大的时候,底数的大小对结果影响不大,因此,一般情况不管底数是多少,都可以省略不写。

在这里插入图片描述
在这里插入图片描述

空间复杂度

空间复杂度 (Space Complexity)是对一个算法在运行过程中临时占用存储空间大小的量度
所以,空间复杂度算的是变量的个数

空间复杂度计算规则基本跟时间复杂度类似,也使用大o渐进表示法。

注意:函数运⾏时所需要的栈空间(存储参数、局部变量、⼀些寄存器信息等)在编译期间已经确定好
了,因此,空间复杂度主要通过函数在运行时显示申请的额外空间来决定。

计算下列代码的空间复杂度:

void BubbleSort(int* a, int n)
{
assert(a);
for (size_t end = n; end > 0; --end)
{
	int exchange = 0;
	for (size_t i = 1; i < end; ++i)
	{
		if (a[i-1] > a[i])
		{
		Swap(&a[i-1], &a[i]);
		exchange = 1;
		}
	} 
	if (exchange == 0)
	break;
	}
}

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

相关推荐

  1. 数据结构-算法复杂

    2024-07-13 14:54:04       36 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-13 14:54:04       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-13 14:54:04       71 阅读
  3. 在Django里面运行非项目文件

    2024-07-13 14:54:04       58 阅读
  4. Python语言-面向对象

    2024-07-13 14:54:04       69 阅读

热门阅读

  1. 神经网络的数学原理

    2024-07-13 14:54:04       24 阅读
  2. 【AI原理解析】—迁移学习(TL)原理

    2024-07-13 14:54:04       20 阅读
  3. 索引原理;为什么采用B+树?

    2024-07-13 14:54:04       22 阅读
  4. 【HBZ分享】如何规避TCP的洪水攻击

    2024-07-13 14:54:04       21 阅读
  5. go-基准测试

    2024-07-13 14:54:04       24 阅读
  6. kafka部署以及常用命令详细总结

    2024-07-13 14:54:04       18 阅读
  7. windows安全加固

    2024-07-13 14:54:04       18 阅读
  8. 微服务架构实战:案例分析与解决方案探讨

    2024-07-13 14:54:04       22 阅读
  9. 【数据结构】B树

    2024-07-13 14:54:04       18 阅读