空间复杂度

所谓一个程序的空间复杂度是指改程序运行所需内存的大小。

空间复杂度的组成

程序所需要的空间主要由以下部分组成:

  1. 指令空间:指编译之后的程序指令所需要的存储空间。
  2. 数据空间:指所有常量和变量值所需要的存储空间。它由两部分组成:一是常量和简单变量所需要的存储空间,二是动态数组和动态实例等动态对象所需要的空间。
  3. 环境栈空间:环境栈用来保存暂停的函数和方法在恢复运行时所需要的信息。

1.指令空间

指令空间的数量取决于如下因素:

  • 把程序转换成机器代码的编译器。
  • 在编译时的编译器选项。
  • 目标计算机。

2.数据空间

     对各种数据类型,C++语言并没有指定他们的空间大小,只是大多数C++编译器有相应的空间分配。

3.环境栈空间

    每当一个函数被调用时,下面的数据将被保存在环境栈中:

  • 返回地址
  • 正在调用的函数的所有局部变量的值以及形式参数的值。(值得注意的是,有些编译器,不论对递归函数还是非递归函数,在函数调用时,都会保存局部变量和形参的值,而有些编译器仅对递归函数才会如此)。

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值