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

有没有教做零食的网站网上推广的平台有哪些

有没有教做零食的网站,网上推广的平台有哪些,albatros wordpress,iis 编辑网站绑定算法时间空间复杂度计算—空间复杂度 空间复杂度定义影响空间复杂度的因素算法在运行过程中临时占用的存储空间讲解 计算方法例子1、空间算法的常数阶2、空间算法的线性阶(递归算法)3、二分查找分析方法一(迭代法)方法二&#xff…

算法时间空间复杂度计算—空间复杂度

  • 空间复杂度定义
  • 影响空间复杂度的因素
    • 算法在运行过程中临时占用的存储空间讲解
  • 计算方法
  • 例子
    • 1、空间算法的常数阶
    • 2、空间算法的线性阶(递归算法)
    • 3、二分查找分析
      • 方法一(迭代法)
      • 方法二(递归法)
    • 4、斐波那契数列
      • 方法一(迭代法)
      • 方法二(递归法)

空间复杂度定义

空间复杂度(Space Complexity)是对一个算法在运行过程中临时占用存储空间大小的量度。
一个算法在计算机存储器上所占用的存储空间,包括程序代码所占用的空间输入数据所占用的空间辅助变量所占用的空间这三个方面。

影响空间复杂度的因素

在这里插入图片描述
注意:
一个算法的空间复杂度只考虑在运行过程中为局部变量分配的存储空间的大小,它包括为参数表中形参变 量分配的存储空间和为在函数体中定义的局部变量分配的存储空间两个部分。若一个算法为递归算法,其空间复杂度为递归所使用的堆栈空间的大小。它等于一次调用所分配的临时存储空间的大小乘以被调用的次数(即为递归调用的次数加1,这个1表示开始进行的一次非递归调用)
递归的空间复杂度: 每次递归所开空间*深度。

算法在运行过程中临时占用的存储空间讲解

1、有的算法只需要占用少量的临时工作单元,而且不随问题规模的大小而改变,我们称这种算法是“就地”进行的,是节省存储的算法,下面会介绍。

2、有的算法需要占用的临时工作单元数与解决问题的规模n有关,它随着n的增大而增大,当n较大时,将占用较多的存储单元,例如快速排序和归并排序算法就属于这种情况。

计算方法

①忽略常数,用O(1)表示
②递归算法的空间复杂度=递归深度n*每次递归所要的辅助空间
③对于单线程来说,递归有运行时堆栈,求的是递归最深的那一次压栈所耗费的空间的个数,因为递归最深的那一次所耗费的空间足以容纳它所有递归过程。

例子

1、空间算法的常数阶

在这里插入图片描述
如上图,这里有三个局部变量分配了存储空间,所以f(n) = 1 + 1 + 1 = 3,根据上面的法则该函数不受n的影响且为常数项,所以空间复杂度记作O(1)。这种与问题的大小无关(n的多少),执行时间恒定的算法,我们称之为具有O(1)的空间复杂度,又叫常数阶。

2、空间算法的线性阶(递归算法)

在这里插入图片描述
如上图,这是一个递归算法(计算从n + (n-1) + (n-2) + … + 2 + 1的和)
每当执行一次该函数就会为tmp分配一个临时存储空间,所以f(n) = 1*(n-1+1) = n,函数是受n影响的所以空间复杂度记为O(n)。

3、二分查找分析

在这里插入图片描述

方法一(迭代法)

	/// <summary>/// 二分查找/// </summary>/// <param name="arr">查找数组</param>/// <param name="len">数组长度</param>/// <param name="num">查找项</param>/// <returns></returns>int BinarySearch(int[] arr,int len,int num){int left = 0;int right = len - 1;int mid;while (left <= right){mid = (left + right) / 2;if (arr[mid] > num)right = mid - 1;else if (arr[mid] < num)left = mid + 1;elsereturn mid;}return -1;}

时间复杂度:
left、right、mid运算次数
f(n1) = 1 + 1 + 1 = 3
我们将While循环中的运算作为一个整体看待,每次都是折半运算次数
f(n2) = log2^n
总运行次数
f(all) = f(n1)+f(n2) = 3 + log2 ^ n
时间复杂度记为:O(log2^n)


空间复杂度:
算法中left、right、mid只创建的次数
s(n) = 1 + 1 + 1 = 3
空间复杂度记为:O(1)

方法二(递归法)

 /// <summary>/// 二分查找(递归法)/// </summary>/// <param name="arr"></param>/// <param name="left"></param>/// <param name="right"></param>/// <param name="num"></param>/// <returns></returns>int BinarySearchRecursion(int[] arr,int left,int right,int num){int mid = (left + right) / 2;if (left <= right){if (arr[mid] > num) {right = mid - 1;return BinarySearchRecursion(arr,left,right,num);}else if (arr[mid] < num){left = mid + 1;return BinarySearchRecursion(arr,left,right,num);}elsereturn mid;}else{return -1;}}

时间复杂度:
运行次数 f(n) = log2 ^ n
时间复杂度记为:O(log2^n)


空间复杂度:
因为整个算法中mid只创建的次数
s(n) = log2 ^ n
空间复杂度记为:O(log2 ^ n)


4、斐波那契数列

斐波那契数列(Fibonacci sequence),又称黄金分割数列、因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为“兔子数列”,指的是这样一个数列:1、1、2、3、5、8、13、21、34、……
这个数列从第3项开始,每一项都等于前两项之和。

如果设F(n)为该数列的第n项(n∈N*),那么这句话可以写成如下形式::F(n)=F(n-1)+F(n-2)

显然这是一个线性的递推数列。
通项公式 :
在这里插入图片描述
上面就是斐波那契数列的递推公式,这样一个完全是自然数的数列,通项公式却是用无理数来表达的。而且当n趋向于无穷大时,前一项与后一项的比值越来越逼近黄金分割0.618
在这里插入图片描述
递推是公式是求解斐波那契数列的一个方法,我们当然也可以用计算机编写程序来求解。

方法一(迭代法)

  /// <summary>/// 斐波那契(迭代法)/// </summary>/// <param name="n"></param>/// <returns></returns>int Fibonacci(int n){if (n <= 0)return -1;if (n == 1 || n == 2)return 1;else{int num = 0;int a = 1;int b = 1;while (n - 2 > 0){num = a + b;a = b;b = num;n--;}return num;}}

时间复杂度:
while以外的算法语句都忽略不计(不随n的变化而变化)
while算法语句所有语句
f(n) = 4 *(n - 2) = 4n - 8
时间复杂度记为:O(n)


空间复杂度:
算法中num、a、b只创建1次
s(n) = 1 + 1 + 1 = 3
空间复杂度记为:O(1)


方法二(递归法)

/// <summary>/// 斐波那契(递归法)/// </summary>/// <param name="n"></param>/// <returns></returns>int FibonacciRecursion(int n){if (n <= 0)return -1;if (n == 1 || n == 2)return 1;return FibonacciRecursion(n - 1) + FibonacciRecursion(n - 2);}

时间复杂度:
递归调用的形参有两个n - 1 和 n - 2
时间复杂度记为:O(2^n)


空间复杂度:
递归的空间复杂度 =(n + 1)* 调用的深度
空间复杂度记为:O(n)(这里可以简单的根据二叉树的层来进行计算)


http://www.tj-hxxt.cn/news/45309.html

相关文章:

  • wordpress顶部栏插件昆明seo建站
  • 自适应网站开发公司学校网站模板
  • 网站排名系统哪个好武汉seo价格
  • 北京网站建设公司收购百度云登陆首页
  • 公司网上注册在哪个网站网站搜索系统
  • 雨发建设集团有限公司网站绍兴seo外包
  • 美国 做网站广州的百度推广公司
  • 渭南韩城优化网站关键词的技巧
  • 自己做网站怎么做的简述seo和sem的区别
  • 新网站该如何做网站优化呢如何创造一个自己的网站
  • 商业网站设计欣赏网店交易平台
  • 深圳知名网站建设哪家好小红书搜索关键词排名
  • 京东联盟的网站怎么做的怎么做游戏推广员
  • 通辽市 做网站站长之家源码
  • 网站建设经费南宁seo内部优化
  • 网站备案更名长沙网络优化产品
  • 做机加工的网站可以发布软文的平台
  • 做门户网站用什么软件商业软文案例
  • 网站开发浏览器兼容性长沙seo网站排名优化公司
  • 大连seo网站推广武汉seo搜索引擎
  • 上海做网站好的公司离我最近的电脑培训中心
  • 怎么免费做公司网站今天重大新闻事件
  • 网站建设一般收多少定金seo教程seo官网优化详细方法
  • 二手车网站软件建设sem竞价托管多少钱
  • 泉州网站建设方案服务360推广登录入口官网
  • 网站制作和维护费用阿里大数据平台
  • 网站 二级域名宁波网站快速优化
  • 搜索网站的设计与建设今天最新疫情情况
  • wpf可以做网站吗软文广告经典案例800字
  • 浙江省建设教育考试中心网站现在最火的推广平台有哪些