【数据结构】算法复杂度

算法复杂度

  • 数据结构
  • 算法
    • 复杂度
  • 大o渐进表示法
  • 空间复杂度

数据结构

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

算法

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

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

复杂度

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

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

大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;
	}
}

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/802097.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2024-07-12升级问题:Android SDK升级导致 Canvas.FULL_COLOR_LAYER_SAVE_FLAG 等标志位无法使用

Canvas.FULL_COLOR_LAYER_SAVE_FLAG 是一个标志位&#xff0c;用于在 Android 的 Canvas 类中保存画布的颜色层。当使用 saveLayer() 方法时&#xff0c;可以传递这个标志位来指示保存整个颜色层。这样&#xff0c;在恢复画布状态时&#xff0c;颜色层也会被恢复。 工程从Andr…

EasyAnimate-v3版本支持I2V及超长视频生成

阿里云人工智能平台&#xff08;PAI&#xff09;自研开源的视频生成项目EasyAnimate正式发布v3版本&#xff1a; 支持 图片&#xff08;可配合文字&#xff09; 生成视频 支持 上传两张图片作为起止画面 生成视频 最大支持720p&#xff08;960*960分辨率&#xff09; 144帧视…

使用 Python 爬虫实现自动获取天气信息并语音播报

简介 在本文中&#xff0c;我将介绍如何使用 Python 编写一个简单的爬虫程序&#xff0c;该程序可以自动获取某个城市的天气信息&#xff0c;并使用语音库将这些信息播报出来。我们将使用 pyttsx3 库进行语音播报&#xff0c;以及 requests 和 lxml 库来获取和解析网页数据。 …

Unity不用脚本实现点击按钮让另外一个物体隐藏

1.首先在场景中创建一个按钮和一个其他随便什么东西 2.点击按钮中的这个加号 3.然后将刚刚你创建的物体拖到这里来 4.然后依次点击下面这些给按钮绑定事件 5.运行游戏并点击按钮&#xff0c;就会发现拖进来的物体消失了 总结&#xff1a;如果按钮的功能单一&#xff0c;可以使用…

新版本安卓更换下载源解决gradle时间太久问题

老版本android studio 解决方法如下 : android studio gradle:build model执行时间太久 最近又做到安卓的任务了,下载的安卓studio最新版 这个版本的android studio 不能用上面那种老版本的方法了,需要更新方法 新版本需要跟换两个地方 gradle/wrapper/gradle-wrapper.proper…

Springcloud (一站式微服务架构的解决方案)

第一章&#xff1a; 理解微服务 - 单体架构 理解微服务 - 垂直架构 理解微服务 - SOA架构 理解微服务 - 微服务架构 第二章&#xff1a;Springcloud技术栈 Springcloud 一站式为微服务架构的解决方案 第三章&#xff1a;服务治理 负载均衡 - 服务端负载 负载均衡 - 客户端负载 …

涌流限制器(ICL):类型、优缺点、安装技巧及故障诊断全解析

涌流限制器&#xff08;简称ICL&#xff09;是一种电子元件或装置&#xff0c;设计用于抑制电气设备在启动瞬间产生的暂态大电流&#xff0c;即涌流。这种涌流通常发生在含有电感元件&#xff08;如变压器、电动机、电容器等&#xff09;的电路中&#xff0c;当电源首次接通时&…

API vs 网页抓取:获取数据的最佳方式

获取准确和及时的数据对于大多数项目至关重要无论是对于企业、研究人员&#xff0c;还是开发人员来说&#xff0c;获取准确和及时的数据都至关重要。收集网页数据主要有两种方法&#xff1a;使用API&#xff08;应用程序接口&#xff09;和网页抓取——哪种方法更适合你的项目呢…

安卓使用Kotlin调用身份证阅读器SDK读取身份证、社保卡信息

步骤一&#xff1a;在app/build.gradle.kts下面添加东信身份证阅读器的读卡库 dependencies {implementation(files("libs/DonseeDevice.aar"))implementation(libs.androidx.core.ktx)implementation(libs.androidx.lifecycle.runtime.ktx)implementation(libs.and…

DAMA学习笔记(六)-数据安全

1.引言 数据安全包括安全策略和过程的规划、建立与执行&#xff0c;为数据和信息资产提供正确的身份验证、授权、访问和审计。数据安全实践的目标是根据隐私和保密法规、合同协议和业务要求来保护信息资产。这些要求来自以下几个方面: 1&#xff09;利益相关方: 应识别利益相关…

Python和C++骨髓细胞进化解析数学模型

&#x1f3af;要点 &#x1f3af; 数学模型邻接矩阵及其相关的转移概率 | &#x1f3af;蒙特卡罗模拟进化动力学 | &#x1f3af;细胞进化交叉图族概率 | &#x1f3af;进化图模型及其数学因子 | &#x1f3af;混合图模式对进化概率的影响 | &#x1f3af;造血干细胞群体的空间…

redis删除策略和淘汰策略

1、redis的删除策略 Redis 是一种内存级数据库&#xff0c;数据都存在内存中&#xff0c;但是针对于已经过期的数据&#xff0c;reids 不 会立刻删除只是会存储在 expires 中&#xff0c;当执行删除策略的时候&#xff0c;才会从 expires 中寻找对应的数据存储的地址&#xff…

《昇思25天学习打卡营第22天|基于MindNLP+MusicGen生成自己的个性化音乐》

学习内容&#xff1a;基于MindSpore的GPT2文本摘要 1.模型简介 MusicGen是来自Meta AI的Jade Copet等人提出的基于单个语言模型&#xff08;LM&#xff09;的音乐生成模型&#xff0c;能够根据文本描述或音频提示生成高质量的音乐样本&#xff0c;相关研究成果参考论文《Simp…

【区块链 + 智慧政务】澳门:智慧城市建设之证书电子化项目 | FISCO BCOS应用案例

2019 年 2 月 27 日&#xff0c;澳门政府设立的澳门科学技术发展基金与微众银行达成合作&#xff0c;通过区块链、人工智能、大数据、 云计算等创新技术&#xff0c;共同推进澳门特区的智慧城市建设与未来型城市发展&#xff0c;提升粤港澳大湾区的科创能力。在澳 门智慧城市建…

股票涨停后还能交易吗?

股票涨停后还能交易吗&#xff1f; 在股票市场中&#xff0c;涨停板是一个常见的现象&#xff0c;它代表着某只股票在一天内的涨幅已经达到了交易所规定的上限。对于许多投资者来说&#xff0c;涨停板既带来了喜悦&#xff0c;也带来了疑惑&#xff1a;股票涨停后&#xff0c;…

Template execution failed: ReferenceError: name is not defined

问题 我们使用了html-webpack-plugin&#xff08;webpack&#xff09;进行编译html&#xff0c;导致的错误。 排查结果 连接地址 html-webpack-plugin版本低(2.30.1)&#xff0c;html模板里面不能有符号&#xff0c;注释都不行 // var reg new RegExp((^|&)${name}([^&…

深度解析:disableHostCheck: true引发的安全迷局与解决之道

在Web开发的浩瀚星空中&#xff0c;开发者们时常会遇到各种配置与调优的挑战&#xff0c;其中disableHostCheck: true这一选项&#xff0c;在提升开发效率的同时&#xff0c;也悄然埋下了安全隐患的伏笔。本文将深入探讨这一配置背后的原理、为何会引发报错&#xff0c;以及如何…

MySQL 一行记录是怎么存储的

文章目录 1. 文件存放目录 && 组织2. 表空间文件的结构3. InnoDB 行格式4. Compact 行格式记录的额外信息1. 变长字段长度列表2. NULL 值列表3. 记录头信息 记录的真实数据1. 定义的表字段2. 三个隐藏字段 5. varchar(n) 中 n 最大取值为多少&#xff1f;6. 行溢出后&a…

Jdk8 Idea Maven Received fatal alert: protocol_version

问题描述 使用idea开发工具&#xff0c;maven加载项目依赖时&#xff0c;出现错误&#xff1a; Could not transfer artfact xxxxxxx from/to maven-dep-repos https://XXXXXXX: Received fatal alert: protocol_version初步思路 用关键字protocol_version 去检索&#xff0…

Nuxt.js头部魔法:轻松自定义页面元信息,提升用户体验

title: Nuxt.js头部魔法&#xff1a;轻松自定义页面元信息&#xff0c;提升用户体验 date: 2024/7/16 updated: 2024/7/16 author: cmdragon excerpt: 摘要&#xff1a;“Nuxt.js头部魔法&#xff1a;轻松自定义页面元信息&#xff0c;提升用户体验”介绍如何使用useHead函数…