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

如何高效建设品牌网站网站开发文件结构组成

如何高效建设品牌网站,网站开发文件结构组成,广州网站建设的地方推荐,网站ui设计是什么如何评判算法好坏?复杂度深度解析 1. 算法效率1.1 如何衡量一个算法好坏1.2 算法的复杂度 2 时间复杂度2.1 时间复杂度的概念2.1.1 实例 2.2 大O的渐进表示法2.3 常见时间复杂度计算举例 3 空间复杂度4 常见复杂度对比5 结尾 1. 算法效率 1.1 如何衡量一个算法好坏 …

如何评判算法好坏?复杂度深度解析

  • 1. 算法效率
    • 1.1 如何衡量一个算法好坏
    • 1.2 算法的复杂度
  • 2 时间复杂度
    • 2.1 时间复杂度的概念
      • 2.1.1 实例
    • 2.2 大O的渐进表示法
    • 2.3 常见时间复杂度计算举例
  • 3 空间复杂度
  • 4 常见复杂度对比
  • 5 结尾


在这里插入图片描述


1. 算法效率


1.1 如何衡量一个算法好坏

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

斐波那契数列的递归方式非常简洁,但简介一定好吗?那该如何衡量其好与坏呢?


1.2 算法的复杂度

算法在编写成可执行程序后,运行时需要消耗时间资源和空间(内存)资源,因此衡量一个算法的好坏,一般是从时间和空间两个维度来衡量的,及时间复杂度空间复杂度
时间复杂度主要衡量一个算法的运行快慢,而空间复杂度主要衡量一个算法运行所需要的额外空间。在计算机发展的早期,计算机的存储容量很小。所以对空间复杂度很是在乎。但是经过计算机行业的迅速发展,计算机的存储容量已经达到了很高的程度。所以我们已经不需要在特别关注一个算法的空间复杂度。


2 时间复杂度


2.1 时间复杂度的概念

时间复杂度的概念:在计算机科学中,算法的时间复杂度是一个函数,他定量描述了该算法的运行时间。
一个算法的运行时间,从理论上说是算不出来的,只有把你的程序放在机器上跑起来,才知道。但是我们需要每个算法都上机测试吗?
是都可以上机,但是这很麻烦,所以才有了时间复杂度这个分析方法。
一个算法所发费的时间和其中的语句执行次数成正比例,算法中的基本操作的执行次数,为算法的时间复杂度
即,找到某条语句与问题规模N之间的数学表达式,就是该算法的时间复杂度。


2.1.1 实例

我们先来看看这段代码:

void Func1(int N)
{int count = 0;for (int i = 0; i < N; i++){for (int j = 0; j < N; j++){++count;}}for (int k = 0; k < 2 * N; k++){++count;}int M = 10;while (M--){++count;}printf("%d\n", count);return 0;
}

Func1的执行次数:F(N)= N^2 + 2*n + 10
但在实际计算时间复杂度时,我们其实并不一定要计算精确的执行次数,而只需要大概的执行次数即可,那么这里我们就要用到大O的渐进表示法


2.2 大O的渐进表示法

大O符号(Big O notation)用于描述函数渐进行为的函数符号
推导大O阶方法:

①: 用常数1取代运行时间的所有加法常数。
②: 在修改后的运行次数函数中,只保留最高阶项。
③: 如果最高阶存在并且不是1,则去掉与这个项相乘的常数,得到的结果就是大O阶。
④: 有一些算法存在最好、最坏和平均的情况,但实际中一般关注的是算法的最坏运行情况。

所以使用大O的渐进表示法以后,Func1的时间复杂度为O(N^2).
通过上面我们很容易发现大O的渐进表示法去掉了那些对结果印象不大的项,简洁明了的表示执行次数。(本质上是计算属于那个量级


2.3 常见时间复杂度计算举例

实例1:

// 计算Func2的时间复杂度?
void Func2(int N)
{int count = 0;for (int k = 0; k < 2 * N ; ++ k){++count;}int M = 10;while (M--){++count;}printf("%d\n", count);
}

3 空间复杂度

空间复杂度也是一个函数表达式,是对一个算法在运行过程中临时占用存储空间大小的量度
空间复杂度不是程序占用了多少byte的空间,因为这个也没太大意义,所以空间复杂度算的是变量的个数
空间复杂度的计算规则基本和时间复杂度的计算类似,也用大O的渐进表示法
注意:函数运行时所需要的栈空间(存储参数、局部变量、一些寄存器信息等)在编译期间已经确定好了,因此空间的复杂度主要是通过函数在运行时显示申请的额外空间来确定。


4 常见复杂度对比

一般算法的常见复杂度如下:在这里插入图片描述
在这里插入图片描述


5 结尾

本篇博客到此就结束了。如果对你有帮助,记得三连哦。感谢您的支持!!!
在这里插入图片描述
在这里插入图片描述

http://www.yayakq.cn/news/420783/

相关文章:

  • 如何说明学校网站建设情况有创意营销型网站建设
  • 海南网站建设开发wordpress主题手机版不显示侧边栏
  • 怎么在手机上制作网站云服务器做网站新手教程
  • 网站上传 空间 数据库推广的软件
  • 如何在年报网站上做遗失公告手机开发者选项在哪里关闭
  • 前端做网站一般用什么框架宜丰做网站的
  • 想建设个人网站去那里建设石家庄php网站建设
  • 安全可信网站营销网站制作方法
  • 淘宝网站网页图片怎么做的网站建设优化扬州
  • 如何建立一个个人博客网站住宅小区物业管理系统网站建设
  • 做私人网站医疗网站建设精英
  • 网站建设教程赚找湖南岚鸿认 可苏州婚庆公司网站建设案例
  • 河北住房和城乡建设部网站建筑工程网上报建网站诚信手册
  • 金华公司建站模板定制型网站设计报价表
  • 做商城网站数据库分类该有哪些什么网站做装修的
  • 哪个网站建设服务器是在国外的wordpress主页标题显示不全
  • 国外网站设计公司企业建站模版
  • 杭州久邦电力建设有限公司网站网站编程代码
  • 企业网站建设后期维护费用HTML5移动端手机网站开发
  • 论坛的网站开发项目百度应用下载安装
  • 手机网站大全推荐河源北京网站建设
  • 游戏网站上做银商为网站人员佛山营销网站建设
  • 米拓模板网站建设昆明网站建设设计
  • 给企业建设网站的意义天津搜索引擎优化公司
  • 建影楼网站多少钱营销型网站易网拓
  • 做一元购物网站个人简历制作免费
  • 网站界面设计如何实现功能美与形式美的统一?hs网站推广
  • 西安市建设局官方网站网站注销备案查询系统
  • 公司换网站换域名 备案wordpress一行太宽了
  • 网站开发与维护都有些什么创意设计素描