浅识数据结构之空间复杂度

ops/2024/10/18 22:30:11/
P. S.:以下代码均在VS2019环境下测试,不代表所有编译器均可通过。
P. S.:测试代码均未展示头文件stdio.h的声明,使用时请自行添加。

  

文章目录

  • 一. 前言
  • 二. 空间复杂度
    • 2.1 概念
    • 2.2 常见的空间复杂度
    • 2.3 不常见的空间复杂度,并无实际应用意义。
  • 三. 结语

一. 前言


  了解 空间复杂度相对于了解 时间复杂度来说较为容易一些。
  因为 时间复杂度需要对程序内部或函数内部的基本语句执行次数进行判断,又时会牵扯到递归,迭代,循环等多重因素,所以计算起来相对复杂。
  而 空间复杂度只是代表着对一个算法在运行过程中 临时占用的储存空间大小的一个量度,并且这个临时的占用大多是指除了主体函数原有的变量之外,再实现算法时额外创建的变量,或是指在 递归等函数调用情况下的函数调用次数。
  下面进入正式内容。



二. 空间复杂度

2.1 概念


   空间复杂度也是一个数学表达式,是对一个算法在运行过程中临时占用存储空间大小的量度 。
   空间复杂度不是程序占用了多少bytes的空间,因为这个也没太大意义,所以空间复杂度算的是变量的个数。
   空间复杂度计算规则基本跟实践复杂度类似,也使用 大O渐进表示法
   注意:函数运行时所需要的栈空间(存储参数、局部变量、一些寄存器信息等)在编译期间已经确定好了,因此空间复杂度主要通过函数在运行时候显式申请的额外空间来确定。
   大O渐进表示法:取影响量最大的项作为O( )的内容,且系数可以忽略。

2.2 常见的空间复杂度


   O( 1 ) :常数值的空间复杂度,一般是指调用函数次数或额外创建变量次数可以通过计数的方式的到确切的值。
   O( N ):一般指递归次数为 N 或创建额外变量次数为 N 时的情形。
   O( N² ) :这种情形相对来说较为少见,但还是作为举例列明,常见的状况有创建了一个额外的二维数组,他们的额外占用空间为未知量一维数组的个数 N × 未知量一维数组中的个数 M,故空间复杂度为 N²,因 N 趋近于无穷时 N 与 M 的差值可以忽略不计 ,直接记为 N²。

2.3 不常见的空间复杂度,并无实际应用意义。


  下面见一个经典的斐波那契数问题:
// 计算斐波那契递归Fib的时间复杂度?
long long Fib(size_t N)
{if(N < 3)return 1;return Fib(N-1) + Fib(N-2);
}

  当我们调用这个函数时,若所求值为第64个斐波那契数时还较为容易计算,不难看出在计算结果时,我们的函数调用了2 ^ ( 64 - 2 ) 次,故我们可以将此函数调用的空间复杂度记为O ( 2^N ) 当我们计算的数值序次偏大时,可能会消耗更多的时间,故这样的函数在实际生活中也并没有很大的应用意义。


  但我们可以对其进行优化,将O ( 2^N ) 转化为 O( N )。
// 时间复杂度:O(N)
unsigned long long Fib(size_t N)
{unsigned long long f1 = 1;unsigned long long f2 = 1;unsigned long long f3 = 0;for (size_t i = 3; i <= N; i++){f3 = f1 + f2;f1 = f2;f2 = f3;}return f3;
}

  此时即使计算1000位次的斐波那契数也毫无鸭梨!!




三. 结语


  十分感谢您观看我的原创文章。
  本文主要用于个人学习和知识分享,学习路漫漫,如有错误,感谢指正。
  如需引用,注明地址。


http://www.ppmy.cn/ops/24552.html

相关文章

学生管理系统[Python语言]

各位大佬好 &#xff0c;这里是阿川的博客 &#xff0c; 祝您变得更强 个人主页&#xff1a;在线OJ的阿川 大佬的支持和鼓励&#xff0c;将是我成长路上最大的动力 阿川水平有限&#xff0c;如有错误&#xff0c;欢迎大佬指正 学生管理系统是计算机专业最基础的一个作业&#…

苹果公司大量订购电容按钮组件,或将用于即将推出的iPhone 16系列

据外媒报道&#xff0c;苹果公司已经从供应商订购了大量电容按钮组件&#xff0c;这些组件据称将用于即将推出的iPhone 16系列。根据《台湾经济日报》的一份报告&#xff0c;该订单包括系统级封装(SIP)模块&#xff0c;模块将用于将电容组件与两个Taptic Engine电机集成在一起。…

01数学建模 -线性规划

1.1线性规划–介绍 翻译翻译什么叫惊喜 1.2线性规划–原理 拉格朗日乘数法手算 最值化 f ( x , y ) , s . t . g ( x , y ) c , 引入参数 λ &#xff0c;有&#xff1a; F ( x , y , λ ) f ( x , y ) λ ( g ( x , y ) − c ) 再将其分别对 x , y , λ 求导&#xff0c…

CSS + HTML

目录 一.CSS&#xff08;层叠样式表&#xff09; 二. CSS 引入方式 三.选择器 3.1 标签选择器 3.2 类选择器 3.3 id选择器 3.4 通配符选择器 3.5 画盒子 四.文字控制属性 4.1字体大小 4.2字体粗细 4.3 字体倾斜 4.4行高 4.5行高--垂直居中 4.6 字体族 4.7 字体复…

All in OpenNJet:OpenNJet 助力Web应用开发

前言 OpenNJet应用引擎是基于 NGINX 的面向互联网和云原生应用提供的运行时组态服务程序&#xff0c;作为底层引擎&#xff0c;OpenNJet实现了NGINX 云原生功能增强、安全加固和代码重构&#xff0c;利用动态加载机制可以实现不同的产品形态&#xff0c;如Web服务器、流媒体服…

【Linux】dlopen: /lib/x86_64-linux-gnu/libm.so.6: version `GLIBC_2.29‘ not found

[30116] Error loading Python lib /tmp/_MEIlvdUu6/libpython3.8.so.1.0: dlopen: /lib/x86_64-linux-gnu/libm.so.6: version GLIBC_2.29 not found (required by /tmp/_MEIlvdUu6/libpython3.8.so.1.0)1 cd到指定路径 cd /usr/local 2 下载 wget http://ftp.gnu.org/gnu/gl…

使用Maven将SpringBoot项目打成jar包

Maven打包最为推荐方式&#xff0c;方便快捷 项目右侧点击Maven&#xff0c;然后在Lifecycle下&#xff0c;点击install

C语言 | Leetcode C语言题解之第52题N皇后II

题目&#xff1a; 题解&#xff1a; struct hashTable {int key;UT_hash_handle hh; };struct hashTable* find(struct hashTable** hashtable, int ikey) {struct hashTable* tmp NULL;HASH_FIND_INT(*hashtable, &ikey, tmp);return tmp; }void insert(struct hashTabl…