《空间复杂度(C语言)》

news2025/5/19 18:18:43

文章目录

    • 前言
    • 一、什么是空间复杂度?
      • 通俗理解:
    • 二、空间复杂度的数学定义
    • 三、常见空间复杂度举例(含C语言代码)
      • 🔹 O(1):常数空间
      • 🔹 O(n):线性空间
      • 🔹 O(n^2):平方空间
    • 四、输入数据占用的空间算吗?
    • 五、递归中的空间复杂度
    • 六、时间复杂度 vs 空间复杂度
    • 七、优化空间复杂度的常见方法
    • 总结

前言

当你写出一段能“跑得起来”的C语言程序时,也许你会觉得:“OK,搞定了!”
但你有没有想过:

  • 这段程序在处理大数据量时,会不会把内存撑爆?
  • 有没有可能用了太多没必要的变量和数组,浪费了资源
  • 如果要在嵌入式系统或内存有限的设备上跑,它还能正常运行吗?

这时,我们就得引入另一个重要的概念 —— 空间复杂度(Space Complexity)

空间复杂度,简单来说,就是分析你的程序到底“吃”了多少内存。它不仅能帮助我们优化程序效率,也能避免内存泄漏、程序崩溃等一系列问题。
在这里插入图片描述

一、什么是空间复杂度?

在学习编程时,我们经常关心程序运行的速度,而空间复杂度关注的则是程序运行时**“占用了多少内存”**。

举个例子:

如果你写了一个程序,它在处理数据时需要开辟额外的数组、结构体、变量等存储信息,那么这些就算作了额外空间。空间复杂度就是用来衡量这部分空间使用情况的。

通俗理解:

你可以把程序比作一个人在做题:

  • 他眼前的试卷是输入数据(这些不算在空间复杂度里)
  • 他额外准备的草稿纸、笔、计算器就是辅助空间(这些要算)

空间复杂度,关注的就是:这个人需要准备多少张草稿纸?


二、空间复杂度的数学定义

空间复杂度一般用大写的 O 符号表示,例如:

  • O(1):常数空间,只用很少的变量
  • O(n):线性空间,比如要开一个数组来存储 n 个元素
  • O(n^2):平方空间,常见于二维数组或矩阵问题

我们不关心精确的字节数,只看输入规模 n 增加时,额外内存的增长趋势


三、常见空间复杂度举例(含C语言代码)

🔹 O(1):常数空间

程序只用固定几个变量,不随输入变化而变化。

int max(int arr[], int n) {
    int maxVal = arr[0];
    for (int i = 1; i < n; i++) {
        if (arr[i] > maxVal) {
            maxVal = arr[i];
        }
    }
    return maxVal;
}

分析:

  • maxVali 是两个变量,和 n 的大小无关
  • 所以空间复杂度是 O(1)

🔹 O(n):线性空间

程序根据输入的大小,分配了等量的内存空间。

int* duplicate(int arr[], int n) {
    int* result = (int*)malloc(n * sizeof(int));
    for (int i = 0; i < n; i++) {
        result[i] = arr[i];
    }
    return result;
}

分析:

  • 申请了一个新的数组 result,长度为 n
  • 所以空间复杂度为 O(n)

🔹 O(n^2):平方空间

使用了二维数组,如矩阵、图的邻接矩阵等情况。

int** createMatrix(int n) {
    int** matrix = (int**)malloc(n * sizeof(int*));
    for (int i = 0; i < n; i++) {
        matrix[i] = (int*)malloc(n * sizeof(int));
    }
    return matrix;
}

分析:

  • 共申请了 n × n 个整数的空间
  • 所以空间复杂度为 O(n^2)

四、输入数据占用的空间算吗?

不算!

空间复杂度只考虑算法运行过程中新增的内存。输入数据(比如函数参数)默认已经存在,不属于算法“额外使用”的空间。


五、递归中的空间复杂度

递归函数往往会消耗较多空间,因为每一次递归调用都会压入一个栈帧。

int factorial(int n) {
    if (n == 1) return 1;
    return n * factorial(n - 1);
}

分析:

  • 递归深度为 n,每次调用都占一份栈空间
  • 所以空间复杂度为 O(n)

六、时间复杂度 vs 空间复杂度

对比项时间复杂度空间复杂度
含义程序运行需要的“时间”程序运行需要的“空间”
衡量单位步数(操作次数)字节数/变量个数等
关注点程序快不快程序占不占内存
示例排序算法耗时哈希表占用内存

有时需要做取舍,比如:

  • 更多空间 来加快处理速度(空间换时间)
  • 更少空间,但处理得慢一些(时间换空间)

七、优化空间复杂度的常见方法

方法举例说明
尽量复用变量不重复创建数组
能用原地修改就原地修改冒泡排序直接在原数组上操作
使用位运算压缩空间布尔数组压缩成位图(bitset)
及时释放动态内存使用 free() 释放 malloc() 空间

总结

  • 空间复杂度衡量的是程序运行时占用的额外内存大小
  • 通常只考虑临时变量、辅助数组、递归栈帧等
  • 表达形式用 O(1)O(n)O(n^2)
  • 递归和大数据处理时要特别注意空间使用
  • 编程中要学会在时间与空间之间做平衡

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

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

相关文章

智能合约安全审计平台——以太坊虚拟机安全沙箱

目录 以太坊虚拟机安全沙箱 —— 理论、设计与实战1. 引言2. 理论背景与安全原理2.1 以太坊虚拟机(EVM)概述2.2 安全沙箱的基本概念2.3 安全证明与形式化验证3. 系统架构与模块设计3.1 模块功能说明3.2 模块之间的数据流与安全性4. 安全性与密码学考量4.1 密码学保障在沙箱中…

【MCP教程】Claude Desktop 如何连接部署在远程的remote mcp server服务器(remote host)

前言 最近MCP特别火热&#xff0c;笔者自己也根据官方文档尝试了下。 官方文档给的Demo是在本地部署一个weather.py&#xff0c;然后用本地的Claude Desktop去访问该mcp服务器&#xff0c;从而完成工具的调用&#xff1a; 但是&#xff0c;问题来了&#xff0c;Claude Deskto…

多个路由器互通(静态路由)无单臂路由(简单版)

多个路由器互通&#xff08;静态路由&#xff09;无单臂路由&#xff08;简单版&#xff09; 开启端口并配ip地址 维护1 Router>en Router#conf t Router(config)#int g0/0 Router(config-if)#no shutdown Router(config-if)#ip address 192.168.10.254 255.255.255.0 Ro…

OpenCV 图形API(38)图像滤波-----Sobel 算子操作函数Sobel()

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 cv::gapi::Sobel 函数是 OpenCV 的 G-API 模块中用于执行 Sobel 算子操作的一个函数&#xff0c;主要用于图像的边缘检测。Sobel 算子通过计算图…

windows系统安装驱动、cuda和cudnn

一、首先在自己的电脑里安装了nvidia的独立显卡 显卡的查找方式&#xff1a; CtrlShiftEsc打开任务管理器&#xff0c;点击性能&#xff0c;点击GPU 0查看显卡型号&#xff0c;如下图所示&#xff1a; 只要电脑中有nvidia的独立显卡&#xff0c;就可以暗转显卡驱动、cuda和cu…

嵌入式开发--STM32软件和硬件CRC的使用--续篇

本文是《嵌入式开发–STM32软件和硬件CRC的使用》的续篇&#xff0c;又踩到一个坑&#xff0c;发出来让大家避一下坑。 按照G0系列的设置&#xff0c;得出错误的结果 前文对应的是STM32G0系列&#xff0c;今天在用STM32G4系列时&#xff0c;按照前文的设置&#xff0c;用硬件…

【Git】git的简单使用

文章目录 1. 基础概念2. 简单使用2.1 git配置2.1.1 git的配置文件2.1.2 .gitignore文件 2.2 创建仓库2.2.1 创建本地仓库2.2.2 github创建远程仓库step1&#xff1a;github新建一个代码仓step2&#xff1a;创建密钥远程仓库相关指令2.2.3 本地仓库 关联 远程仓库 2.3 分支2.3.1…

[Web 安全] Web 信息收集 —— 信息收集流程

&#x1f31f; 想系统化学习 Web 渗透&#xff1f;看看这个&#xff1a;[Web 安全] Web 安全攻防 学习手册 提示&#xff1a;本章不涉及任何具体信息收集技术&#xff0c;仅仅是讲解收集这些信息我能干啥&#xff0c;以及如何才能比较全面的收集信息。 0x01&#xff1a;信息收…

内部聊天软件,BeeWorks-安全的企业内部通讯软件

企业在享受数据便利的同时&#xff0c;如何保障企业数据安全已经成为无法回避的重要课题。BeeWorks作为一款专为企业设计的内部通讯软件&#xff0c;通过全链路的安全能力升维&#xff0c;为企业提供了一个安全、高效、便捷的沟通协作平台&#xff0c;全面保障企业数据安全。 …

应用篇02-镜头标定(上)

本节主要介绍相机的标定方法&#xff0c;包括其内、外参数的求解&#xff0c;以及如何使用HALCON标定助手实现标定。 计算机视觉——相机标定(Camera Calibration)_摄像机标定-CSDN博客 1. 原理 本节介绍与相机标定相关的理论知识&#xff0c;不一定全&#xff0c;可以参考相…

【UE5 C++】“ProceduralMeshComponent”的使用记录

效果 如下所示&#xff0c;通过“ProceduralMeshComponent”创建了一个自定义形状的Mesh&#xff0c;并且该Mesh包含碰撞信息&#xff0c;然后2s后更新Mesh形状。 步骤 1. 在“xxx.Build.cs”中引入“ProceduralMeshComponent”模块 2. 新建一个Actor类&#xff0c;这里命名为…

(leetcode算法题)309. 买卖股票的最佳时机含冷冻期

按照题目要求&#xff0c;研究对象是最后一天结束后获得的最大利润 那么就可以把问题拆分成 第 1 天结束后获得的最大利润&#xff0c; 第 2 天结束后获得的最大利润&#xff0c; 第 i 天结束后获得的最大利润&#xff0c; 由于规则中强调不能同时参与多笔交易&#xff0c…

Chrome漏洞可窃取数据并获得未经授权的访问权限

在发现两个关键漏洞后,谷歌发布了Chrome浏览器的紧急安全更新。这些漏洞可能允许攻击者窃取敏感数据并未经授权访问用户系统。 这些缺陷被识别为CVE-2025-3619和CVE-2025-3620,在Windows和Mac的135.0.7049.95/.96之前影响Chrome版本,影响Linux的135.0.7049.95/.96。该更新将在…

.net core 项目快速接入Coze智能体-开箱即用-全局说明

目录 一、Coze智能体的核心价值 二、开箱即用-效果如下 三 流程与交互设计 为什么要分析意图&#xff0c;而不是全部交由AI处理。 四 接入前的准备工作 五&#xff1a;代码实现----字节Coze 签署 JWT和获取Token .net core 项目快速接入Coze智能体-开箱即用 .net core快…

风丘年度活动:2025年横滨汽车工程展览会

| 展会简介&#xff1a; 2025年横滨汽车工程展览会&#xff0c;是由日本汽车工程师学会&#xff08;JSAE&#xff09;精心主办的一场行业盛会。预计届时将汇聚超550家参展商&#xff0c;设置1300个展位&#xff0c;展览面积超过20000平方米。展会受众广泛&#xff0c;面向汽车…

Redis线上操作最佳实践有哪些?

大家好&#xff0c;我是锋哥。今天分享关于【Redis线上操作最佳实践有哪些?】面试题。希望对大家有帮助&#xff1b; Redis线上操作最佳实践有哪些? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 在使用 Redis 时&#xff0c;尤其是在生产环境中&#xff0c;合理…

Redis——五种数据类型

目录 前言 1.String 1.1RAW编码 1.2EMBSTR编码 1.3 INT编码 2.List 3.Set 3.1 InSet编码转化成Dict编码 4.ZSet 4.1结合SkipList和HT实现 4.2使用ZipList实现 4.3编码转换 4.4 ZipList排序功能 5.Hash 5.1Hash底层存储结构 6.Redis数据结构和数据类型关系图 前言…

Godot学习-创建简单动画

文章目录 1、准备工作Godot资源 2、创建项目3、创建结点4、创建动画1、创建动画2、添加轨道3、创建关键帧3.1 第一个关键帧3.2 第二个关键帧 5、加载后自动播放6、动画循环7、轨道设置1、轨道更新模式2、轨迹插值3、其他属性的关键帧4、编辑关键帧5、使用 RESET 轨道6、洋葱皮 …

论文阅读VACE: All-in-One Video Creation and Editing

code&#xff1a;https://github.com/ali-vilab/VACE 核心 单个模型同时处理多种视频生成和视频编辑任务通过VCU&#xff08;视频条件单元&#xff09;进行实现 方法 视频任务 所有的视频相关任务可以分为4类 文本生视频 参考图片生视频 视频生视频 视频mask生视频 VCU …

JavaSE学习(前端初体验)

文章目录 前言一、准备环境二、创建站点&#xff08;创建一个文件夹&#xff09;三、将站点部署到编写器中四、VScode实用小设置五、案例展示 前言 首先了解前端三件套&#xff1a;HTML、CSS、JS HTML&#xff1a;超文本标记语言、框架层、描述数据的&#xff1b; CSS&#xf…