当前位置: 首页 > news >正文

网站建设 网站维护网页设计案例

网站建设 网站维护,网页设计案例,营销型网站建设 高校邦,百度没有投放的网站点击目录 1.空间复杂度 1.1 例子 1.2 空间的特殊性质 写在最后: 1.空间复杂度 空间复杂度也是一个数学表达式, 是对一个算法在运行过程中临时占用存储空间大小的量度。 他也是用大O渐进表示法。 1.1 例子 例1: 冒泡排序: v…

目录

1.空间复杂度

1.1 例子

1.2 空间的特殊性质

写在最后:


1.空间复杂度

空间复杂度也是一个数学表达式,

是对一个算法在运行过程中临时占用存储空间大小的量度。

他也是用大O渐进表示法。

1.1 例子

例1:

冒泡排序:

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;}
}

这个是开辟了常数个的空间,

(创建变量就是开辟空间)

它创建了几个变量,所以是开辟了常数个的空间,

所以他的空间复杂度是O(1)。

例2:

斐波那契数列:

long long* Fibonacci(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;
}

这里用malloc开辟了n个以上的空间,

所以它的空间复杂度是O(N)。

例3:

阶乘递归:

long long Fac(size_t N)
{if (N == 0)return 1;return Fac(N - 1) * N;
}

这段代码,

因为函数递归,建立函数栈帧,

而函数栈帧里有常数个(空间)变量开辟,

而这段代码,建立了N+1个函数栈帧,

所以它的空间复杂度是O(N)。

1.2 空间的特殊性质

例4:

long long Fib(int N)
{if (N < 3)return 1;return Fib(N - 1) + Fib(N - 2);
}

这段代码的时间复杂度是O(2的N次方)。

但是,它的空间复杂度呢?

实际上,他的空间复杂度是O(N),而不是O(2的N次方)。

为什么呢?

因为函数递归的过程中会建立栈帧,而这段代码在进行递归的时候,

并不会一直递归到最后才返回,

当它递归到一定程度是,会有函数提前返回,

导致栈帧销毁,当新的栈帧建立的时候,

空间就会被重复使用,

例:

#include <stdio.h>void f1()
{int b = 0;printf("%p\n", &b);
}void f2()
{int a = 0;printf("%p\n", &a);
}int main()
{f1();f2();return 0;
}

输出:

 我们发现,当f1函数的栈帧销毁后,

f2函数栈帧建立,创建的变量地址与f1中创建的变量地址相同,

这就是空间重复利用的特性。

例:

#include <stdio.h>void f1()
{int b = 0;printf("%p\n", &b);
}void f2()
{int a = 0;printf("%p\n", &a);f1();
}int main()
{f2();return 0;
}

输出:

 当f1函数的栈帧没有销毁,

f2函数的变量自然用不了f1函数的空间,

所以他们的地址当然不同了。

写在最后:

以上就是本篇文章的内容了,感谢你的阅读。

如果喜欢本文的话,欢迎点赞和评论,写下你的见解。

如果想和我一起学习编程,不妨点个关注,我们一起学习,一同成长。

之后我还会输出更多高质量内容,欢迎收看。

http://www.yidumall.com/news/62457.html

相关文章:

  • 关于网站的建设百度seo关键词优化工具
  • 软件开发是怎么开发的啊seo研究中心vip课程
  • 人才网站 建设好 窗口京津冀协同发展
  • 网站设计基础教程html5+css3源代码龙岩网站推广
  • 蒙古文网站建设工作计划性能优化工具
  • 怀化招标网站交换链接案例
  • 湖州做网站的公司销售平台有哪些
  • 一个网站是怎么建立的网络营销考试答案
  • 网站流量变现十大网络营销经典案例
  • 周口网站设计免费的外链网站
  • 千图网素材下载网站优质友情链接
  • 如何把php做的网站做成app百度网页版主页
  • 网站哪些付款二维码是怎么做的seo推广话术
  • ui设计和网站开发网上做广告宣传
  • 金牌网站设计网站建设做网站需要多少钱 都包括什么
  • 老薛主机用wordpressseo外包公司报价
  • 建设工程资料下载网站广告公司业务推广
  • 如何做中英版网站推广发帖网站
  • 手表网站海马300米潜水表今日全国疫情一览表
  • 山东网站建设公司免费注册推广网站
  • 网站建设公司首页网络服务商
  • 建设网站用什么网络好平台运营推广
  • 本地搭建的wordpress怎么外网访问专业放心关键词优化参考价格
  • 车工订单网站什么软件可以发帖子做推广
  • wordpress 迁移升级成都百度seo公司
  • 住房和城乡建设厅网站首页怎么免费制作网页
  • 盐城做企业网站多少钱下载百度app到手机上
  • 怎样自学做网站需要多少钱网站排名查询软件
  • 网站开发的项目需求浏阳廖主任打人
  • 专注赣州网站建设网络营销策划书总结