算法的特性和空间复杂度---数据结构

news2025/1/12 3:02:13

 

目录

前言:

1.算法

1.1算法的特性

1.2设计算法

2.空间复杂度

3.学习复杂度的意义


❤博主CSDN:啊苏要学习

    ▶专栏分类:数据结构◀

  学习数据结构是一件有趣的事情,希望读者能在我的博文切实感受到数据之间存在的关系,在对数据元素进行操作的时候,能心中有数,脑中有画! 


 

前言:

  在前面我们已经讲过时间复杂度了,空间复杂度也几乎是八九不离十,我们这节主要来讲讲一个好的算法需要满足什么样的特点。

1.算法

  算法实际上就是一组一组的操作,在计算机上表现为一组指令,让计算机按照我们想要的逻辑进行运算,并能有效的解决实际问题

1.1算法的特性

  算法具有五个特性,输入和输出、有限性和可行性以及确定性

  •   输入和输出是提供数据和返回结果的代名词,一个算法可以没有输入,也可以有多个输入,取决于具体需求。但输出是必须有的,如果一个算法没有将其计算的结果返给我们使用,那还要这个算法干嘛呢
  • 有限性指的是实现解决问题算法的指令是有限的,执行完后自动会结束程序,并且条指令,每个步骤所用的时长都在可以接收的时间内
有限性指两方面
指令的数量是有限的指令执行时间可接受
  • 可行性是指在实现算法的整个过程中,每一个步骤的是合理、可以实现的、也就是不会出错,可以得到正确的结果
  • 确定性,算法的每一个步骤只能有一种结果,不管在什么样的环境下、在什么编译器上,运行算出来的结果是唯一的

1.2设计算法

  1.设计算法,需要我们能够正确的表达逻辑,以解决实际问题,这个要求我们对算法的设计要有正确性

  算法的正确性指算法具有完整的结构,包括输入、输出、和加工处理数据的过程中是唯一性的,最终能够得到正确的答案

  算法正确的四大层次:

  1. 算法程序没有语法上的错误(没有语法错误时最基础的)
  2. 算法对于合理数据的输入能够得出正确的结果
  3. 算法能对不恰当的数据输入返回令人满意的信息反馈(而不是输入不合理的数据后就跑出一些随意的值)
  4. 算法对精心挑选的具有钻牛角尖性质的数据仍能处理得出满足要求的输入结果

  对于这四种境界,层次1是最低端的,层次4在一般情况下是很难达到的,我们退而求其次,第3层是能满足大部分要求并且被我们当成是算法是否正确的标准

  算法的可读性算法设计,不是为了让人读不懂,而是为了具有可读性,便于交流,以及后期的维护

  一个算法,如果只能给敲这段代码的人和计算机理解,那么从技术角度上来看,可能这个人是大神,别人看不懂,要不就是敲的令人看不懂。一般没注释的代码,都需要花费别人很多时间去理解。我们不追求花里胡哨,简单易懂,质量高的代码才是我们追求的

  算法的健壮性当输入的数据不合理的时候,会有特殊的情况处理,要么是给程序员提示出错,要么抛出异常报错而不是编写的代码隐晦性的存在错误,但不是致命的,单独跑没问题,当在工程里将代码合在一起的时候,跑起来程序就挂了,这时要找错误那简直是程序员噩梦

  算法的时间效率高、存储量低算法的时间复杂度要尽可能的小,时间效率要追求高。存储量低,不希望算法在执行的时候对内存空间的开销太多

  算法的特性和算法的设计怎么记?我们这样记:算法设计里有个正确性,这个正确性要求算法是一个完整的算法。那么就要有输入输出结果要想正确,计算过程肯定是唯一的,我们怎么得出结果是正确的呢?那是因为算法具有有限性(计算机在短时间内跑的出结果让我们看到是正确的)和可行性(在计算机中可以实现)

  博主相信读者多看几遍,算法的特性就记下来了~,而算法设计的要求其实比较容易理解滴。

2.空间复杂度

  前面我们讲过算法的时间复杂度,这里我们补充一下算法的空间复杂度。

  链接:时间复杂度

  在以前,计算机的内存是很小的,内存很珍贵,当时考虑的更多是空间复杂度,现在存储空间是足够了的,我们追求的是时间上的效率, 当然空间开销小也是需要的,毕竟在大数据时代,即使内存变多了,也不是让我们来浪费的理由

  空间复杂度:并不是算占用的字节数,而是算创建变量的个数

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、整型变量n,还有size_t类型end变量、size_t类型i变量、整型变量exchange变量总共五个。是常数,所以空间复杂度是O(1)

  空间复杂度和时间复杂度的都是同样用大O渐进表示法

  exchange在进入循环时创建,出了循环时被销毁。在这个重复的过程中,是不是应该像计算时间复杂度那样按次数来算空间中变量的创建次数吗不是的,次数在时间上有累计,在空间上不累计

  空间复杂度是在创建最多额外变量时候,变量的个数才是空间复杂度的数,也就是要在变量最多的时候,计算这个时候占的空间多少

long long* Fib(size_t n)
{
    if(n == 0)
        return NULL;
    long long* fibarray = (long long*)malloc((n+1) * sizeof(long long));
    fibarray[0] = 0;
    fibarray[1] = 1;
    for(int i = 2; i <= n; i++)
    {
        fibarray[i] = fibarray[i-1] + fibarray[i-2];
    }
    return fibarray;
}

  计算斐波那契数列的空间复杂度:size_t n 是一个变量,malloc开辟了n+1个元素的数组大小,    int i也是一个变量,这里面总共的变量数是N+3。大O表示法,对空间复杂度贡献值最大的是N,所以空间复杂度是O(N)

  一般情况下,我们都是开辟常数个变量或是开辟N个元素的数组,对应的空间复杂度是O(1)和O(N)

  用递归求阶乘的空间复杂度:

  在算阶乘的时候,我们求N的阶乘,就需要调用N次函数,每次函数都会创建常量个变量,最终空间复杂度为O(N)

  注意:所有的空间在程序结束后归还操作系统;在往下递归的时候,前面的函数还没结束,信息仍保留着,只有在回归,回溯的时候才一个一个销毁

3.学习复杂度的意义

  不管是时间复杂度也好,空间复杂度也罢。我们为什么要学这些东西,我只要能写出代码,能跑起出正确结果就OK了,学这个干嘛?如果你在问这个,只能说你对还没在玩"计算机"。

  • 首先,我们在刷题的时候,经常会有时间复杂度的限制、空间复杂度的限制。学完后我们就懂题目应该怎么做
  • 其次,学完这些复杂度能够促进我们思考更好的算法,解决现有的效率低,占用存储量大的算法,在这探索的过程中开拓新思维,相当于在玩的感觉。

  OK,学到这里,我们对数据结构里的基础知识都掌握了,接下来的数据结构知识主要是写代码题了,跟博主一起学吧!


结语:希望读者读完能有所收获!对数据结构有进一步的认识!✔

  读者对本文不理解的地方,或是发现文章内容上有误等,请在下方评论留言告诉博主哟~,也可以对博主提出一些文章改进的建议,感激不尽!最后的最后!

  ❤求点赞,求关注,你的点赞是我更新的动力,一起进步吧。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【3dmax】常用的快捷键总结以及如何修改快捷键

&#x1f497; 未来的游戏开发程序媛&#xff0c;现在的努力学习菜鸡 &#x1f4a6;本专栏是我关于建模的笔记 &#x1f236;本篇是3dmax常用的快捷键总结以及如何修改快捷键 3dmax常用的快捷键总结以及如何修改快捷键 3dmax常用快捷键如何添加或修改快捷键 3dmax常用快捷键 视…

go pprof性能调优工具

go pprof 一、性能调优原则二、pprof1、pprof 功能简介2、pprof 排查实战前置工作a、CPUb、Heapc、goroutined、mutexe、block 3、pprof 的采样过程和原理a、cpub、heapc、goroutine && threadCreated、block && mutex 三、调优流程1、业务优化a、流程 2、基础…

2023.4.17-4.23 AI行业周刊(第146期):创业要趁早

最近有很多外部拓展培训的需求&#xff0c;联盟的共学课程培训&#xff0c;公司视觉软件的培训&#xff0c;行业课程的培训&#xff0c;每一项培训听起来简单&#xff0c;但是其实都需要大量的时间精力。 前两年也准备过一份《30天入门人工智能》的视频课程&#xff0c;总共31…

Ansible自动化部署工具|各个模块的使用

Ansible自动化部署工具|各个模块的使用 一、自动化运维工具—Ansible二、安装Ansible查询webserver组中主机的日期 三 Ansible常用模块(1) ansible命令行模块(2) command模块(3) shell模块(4) cron模块(5) user模块(6) grup模块(7) copy模块(8) file模块(9) ping模块(10) servi…

内网穿透NPS和宝塔Nginx配合使用,开启SSL访问本地局域网网络

并非为了教学&#xff0c;仅供自己记录&#xff0c;方便下次用。所以内容不会刻意花时间写的很细节详细。 1. 服务器NPS配置 NPS install安装后&#xff0c;配置文件会在其他位置&#xff0c;通过是 /etc/nps/nps.conf目录。 找到进行修改&#xff0c;主要修改的是http_proxy_p…

【flask】三种路由和各自的比较配置文件所有的字母必须大写if __name__的作用核心对象循环引用的几种解决方式--难Flask的经典错误

三种路由 方法1&#xff1a;装饰器 python C#, java 都可以用这种方式 from flask import Flask app Flask(__name__)app.route(/hello) def hello():return Hello world!app.run(debugTrue)方法2: 注册路由 php python from flask import Flask app Flask(__name__)//app…

【以太坊 Solidity】管理员读写权限/访问控制/角色控制

摘要 在 Solidity 语言的多继承中&#xff0c;若多个合约共同继承一个父合约&#xff0c;则这多个合约 共享 父合约中的变量和函数。 1.测试的智能合约 合约继承路线如下&#xff1a; #mermaid-svg-DtimeTjOch5CJh50 {font-family:"trebuchet ms",verdana,arial,s…

应用,auto,内联函数

6.引用&#xff1a; //指针 int main() {int a 0;int& b a;int& c b;int& d c;cout << &a << endl;cout << &b << endl;cout << &c << endl;cout << &d << endl;b;d;cout << a <<…

WEB攻防通用漏洞跨域CORS资源JSONP回调域名接管劫持

目录 一、同源策略&#xff08;SOC&#xff09; 二、跨域资源&#xff08;COSP&#xff09; 三、回调跨域&#xff08;JSOP&#xff09; 四、CORS资源跨域-敏感页面原码获取 五、JSONP 回调跨域-某牙个人信息泄露 六、子域名劫持接管 一、同源策略&#xff08;SOC&#x…

C#手麻系统源码, 基于前端Winform+后端WCF +sqlserver 开发

手麻系统源码&#xff0c;自动生成电子单据 基于C# 前端框架&#xff1a;Winform后端框架&#xff1a;WCF 数据库&#xff1a;sqlserver 开发的手术室麻醉临床信息系统源码&#xff0c;应用于医院手术室、麻醉科室的计算机软件系统。该系统针对整个围术期&#xff0c;对病人…

Buffer Pool介绍

Buffer Pool基本概念 Buffer Pool&#xff1a;缓冲池&#xff0c;简称BP。其作用是用来缓存表数据与索引数据&#xff0c;减少磁盘IO操作&#xff0c;提升效率 Buffer Pool由 缓存数据页(Page) 和 对缓存数据页进行描述的控制块 组成, 控制块中存储着对应缓存页的所属的 表空…

English Learning - L3 综合练习 1 VOA-Color 2023.04.26 周三

English Learning - L3 综合练习 1 VOA-Color 2023.04.26 周三 主题整体听一遍精听句子 1扩展 way of doing | way to do sth 句子 2扩展 Expression扩展 base 句子 3句子 4扩展 red-hot 句子 5句子 6扩展 fiery 句子 7句子 8句子 9句子 10句子 11扩展 born 句子 12句子 13句子…

Haar特征和级联分类器目标检测介绍及应用

文章目录 Haar特征和级联分类器目标检测介绍及应用1. Haar特征2. 级联分类器3. 实现步骤4.尝试训练自己的级联分类器4. 应用示例 Haar特征和级联分类器目标检测介绍及应用 Haar特征和级联分类器是一种经典的目标检测算法&#xff0c;适用于检测物体在图像中的位置、大小和姿态…

卷积神经网络算法解读

神经网络算法解读 机器学习流程&#xff1a; 数据获取特征工程建立模型评估与应用 图像数据是一个矩阵300 * 100 * 3 线性函数分类方法&#xff1a;分类&#xff08;wxb线性回归&#xff09; 损失函数&#xff1a;预测值与实际值之间的差异值 softmax分类器&#xff1a; 神…

(Python)Jupyter Notebook无法运行代码,且提示error和自动保存失败时如何操作?无法链接内核?

目录 一、报错情形 1、运行代码时跳转下一行&#xff0c;无法执行代码。 2、在修改文件名是提示失败&#xff0c;出现“error”字样。 二、深层原因 三、解决方案 四.建议使用原环境 Anaconda的Jupyter Notebook作为优秀的网页编辑器&#xff0c;非常适用于编写Python程序…

ubuntu16.04升级到20.04后报错 By not providing “FindEigen.cmake“

编译问题&#xff1a; CMake Error at modules/perception/lidar/CMakeLists.txt:14 (find_package): By not providing "FindEigen.cmake" in CMAKE_MODULE_PATH this project has asked CMake to find a package configuration file provided by "Eigen&…

黑马Redis入门到实战(基础篇)

Redis基础篇 Redis的类型和常见命令以及客户端使用 目录 1 .初识Redis 1 .1 .认识NoSQL 1 .1 .1 .结构化与非结构化 1 .1 .2 .关联和非关联 1 .1 .3 .查询方式 1 .1 .4 .事务 1 .1 .5 .总结 1 .2 .认识Redis 1 .3 .安装Redis 1 .3 .1 .依赖库 1 .3 .2 .上传安装包并解压 1 .3 .…

音视频八股文(8)-- h264 AnnexB三层结构

NALU(Network Abstract Layer Unit) ⾳视频编码在流媒体和⽹络领域占有重要地位&#xff1b;流媒体编解码流程⼤致如下图所示&#xff1a; H264简介 H.264从1999年开始&#xff0c;到2003年形成草案&#xff0c;最后在2007年定稿有待核实。在ITU的标准⾥称为H.264&#xff0c…

使用QtInstallerFramework制作安装包总结

一、linux下使用QtInstallerFramework制作安装包 4.0.1版本的QtInstallerFramework-linux-x64.run在linux中运行报错&#xff1a; libdbus-1.so.3 no version information availabe 换成3.0.4版本的就好了&#xff1a;https://download.qt.io/official_releases/qt-installer-…

GEE:MODIS计算遥感指数(NDVI、BSI、NDSI、EVI、LSWI、SIPI、EBI等)

作者:_养乐多_ 本文将介绍如何使用Google Earth Engine(GEE)进行遥感影像分析,具体地,使用MODIS数据集计算和可视化几种植被指数,以评估植被生长的状况,或者作为随机森林分类器训练需要的特征变量。 主要包括,NDVI、BSI、NDSI、EVI、LSWI、SIPI、EBI等。 NDVI(Normal…