论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
IT评测·应用市场-qidao123.com技术社区
»
论坛
›
物联网
›
物联网
›
《空间复杂度(C语言)》
《空间复杂度(C语言)》
火影
论坛元老
|
5 天前
|
显示全部楼层
|
阅读模式
楼主
主题
1739
|
帖子
1739
|
积分
5217
前言
当你写出一段能“跑得起来”的C语言程序时,也许你会觉得:“OK,搞定了!”
但你有没有想过:
这段程序在处理
大数据量
时,会不会把内存撑爆?
有没有可能用了太多没必要的变量和数组,
浪费了资源
?
假如要在嵌入式系统或内存有限的装备上跑,它还能正常运行吗?
这时,我们就得引入另一个告急的概念 ——
空间复杂度(Space Complexity)
。
空间复杂度,简朴来说,就是分析你的程序到底“吃”了多少内存。它不但能帮助我们优化程序服从,也能制止内存泄漏、程序崩溃等一系列标题。
一、什么是空间复杂度?
在学习编程时,我们经常关心程序运行的
速度
,而空间复杂度关注的则是程序运行时**“占用了多少内存”**。
举个例子:
假如你写了一个程序,它在处理数据时必要开辟额外的数组、结构体、变量等存储信息,那么这些就算作了
额外空间
。空间复杂度就是用来权衡这部分空间使用情况的。
普通理解:
你可以把程序比作一个人在做题:
他面前的试卷是
输入数据
(这些不算在空间复杂度里)
他额外准备的草稿纸、笔、盘算器就是
辅助空间
(这些要算)
空间复杂度,关注的就是:
这个人必要准备多少张草稿纸?
二、空间复杂度的数学定义
空间复杂度一般用大写的 O 符号表示,例如:
O(1):常数空间,只用很少的变量
O(n):线性空间,比如要开一个数组来存储 n 个元素
O(n^2):平方空间,常见于二维数组或矩阵标题
我们不关心精确的字节数,只看
输入规模 n 增加时,额外内存的增长趋势
。
三、常见空间复杂度举例(含C语言代码)
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
火影
论坛元老
这个人很懒什么都没写!
楼主热帖
最全Windows98原版系统镜像下载(特点 ...
如何配置 SLO
Linux 基本指令
SAP各模块优缺点和发展简析
Spring(SpringBoot)--解决拦截器中注入 ...
Spring Security登录表单配置(3) ...
Redis 原理 - String
软件项目管理 4.3.敏捷需求建模方法 ...
用python反弹shell
Kubernetes(k8s)CNI(flannel)网络 ...
标签云
AI
运维
CIO
存储
服务器
快速回复
返回顶部
返回列表