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

网站建设公司 壹宇网络哪家网络营销好

网站建设公司 壹宇网络,哪家网络营销好,wordpress 缩略图优化,免费搭建私人网站专栏:数据结构 个人主页:HaiFan. 专栏简介:开学数据结构,接下来会慢慢坑新数据结构的内容!!!! 时间复杂度前言1.算法效率1.1如何衡量一个算法的好坏1.2算法的复杂度2.时间复杂度2.1大…

专栏:数据结构
个人主页:HaiFan.
专栏简介:开学数据结构,接下来会慢慢坑新数据结构的内容!!!!

时间复杂度

  • 前言
  • 1.算法效率
    • 1.1如何衡量一个算法的好坏
    • 1.2算法的复杂度
  • 2.时间复杂度
    • 2.1大O的渐进表示法
    • 2.2实例
      • 1.常数次
      • 2.O(M+N)
      • 3.O(N)
      • 4.logN

前言

在这里插入图片描述

什么是数据结构

数据结构是计算机存储,组织数据的方式,指相互之间存在一种或多种特定关系的数据与元素的集合

什么是算法

算法(Algorithm):就是定义良好的计算过程,他取一个或一组的值为输入,并产生出一个或一组值作为 输出。简单来说算法就是一系列的计算步骤,用来将输入数据转化成输出结果

1.算法效率

1.1如何衡量一个算法的好坏

比如以下的算区间和的代码

#include <iostream>
using namespace std;
const int N = 1e5 + 10;
int a[N];
int s[N];
int main()
{int n, m;cin >> n >> m;for (int i = 1; i <= n; i++){cin >> a[i];}while (m--){int l, r;cin >> l >> r;int sum = 0;for (int i = l; i <= r; i++){sum += a[i];}cout << sum << endl;}for (int i = 1; i <= n; i++){s[i] = s[i - 1] + a[i];}return 0;
}

实现这个区间和很简单,代码也很简洁,但是,简洁一定好吗?如何衡量代码的好与坏呢?

1.2算法的复杂度

举个例子:

小兰写了一个冒泡排序

小张写了一个快速排序

小兰和小张执行同一组数据,小兰花了3s,小张花了5s。

这样能说明冒泡排序的效率比快速排序的效率高吗?

答案是:不能的。


算法在编写成可执行程序后,运行时需要耗费时间资源和空间资源。因此衡量一个算法的好坏,一般是从时间和空间两个维度来衡量的,即时间复杂度和空间复杂度。

时间复杂度主要是用来衡量一个算法的运行快慢,

空间复杂度主要是用来衡量一个算法运行所需要的额外空间。

2.时间复杂度

时间复杂度:在计算机科学中,算法的时间复杂度是一个函数,他定量描述了该算法的运行时间,一个算法执行所耗费的时间,从理论上说是不能算出来的,只有把程序放在机器上跑起来,才知道,但是每个代码都需要进行一次测试吗?虽然可以,但会很麻烦,所以就有了时间复杂度这个分析方式,一个算法所花费的时间与其中语句的执行次数成正比例,算法中的基本操作的执行次数,为算法的时间复杂度

即:找到某条基本语句与问题规模N之间的数学表达式,就是算出了该算法的时间复杂度

#include <iostream>using namespace std;int main()
{int n;cin >> n;int ret = 0;for (int i = 1; i <= n; i++){for (int j = 1; j <= n; j++){ret++;}}for (int i = 1; i <= n; i++){ret++;}int m = 100;while (m--){ret++;}cout << ret;return 0;
}

那么,这个代码中的ret共执行了多少次呢?

在代码开始,有一个双重循环,这个时候,ret++就执行了n*n次,后面又有一个循环,这个时候ret++执行了n次,最后又执行了m次ret++;

我们可以推出ret的次数:

F(n) = n*n + n + m

m是一个常数,表达式可以写成

F(n) = n * n + n + 100

  • n = 10 F(n) = 100+10+100=210
  • n = 100 F(n) = 100*100+100+100=1200

依次类推,当n特别大的时候,得到的函数值也是特别大的。


实际中,我们计算时间复杂度时,其实不一定要算执行次数,只需要计算大概执行次数,这就需要使用大O的渐进表示法

2.1大O的渐进表示法

大O符号(Big O notation):是用于描述函数渐进行为的数学符号。

推导大O阶方法

  1. 用1来取代运行时间中的所有加法常数
  2. 在修改后的运行次数函数中,只保留最高阶项。
  3. 如果最高阶项存在且不是1,则去除与这个项目相乘的常数,得到的结果就是大O阶

使用大O阶表示上面代码的时间复杂度:

O(N^2)

大O的渐进表示法去掉了那些对结果影响不大的项。


有些算法的时间复杂度存在最好,平均和最坏情况

最坏情况:任意输入规模的最大运行次数(上界)

平均情况:任意输入规模的期望运行次数

最好情况:任意输入规模的最小运行次数(下界) 例如:在一个长度为N数组中搜索一个数据x

最好情况:1次找到

最坏情况:N次找到

平均情况:N/2次找到

在实际中一般情况关注的是算法的最坏运行情况,所以数组中搜索数据时间复杂度为O(N)

2.2实例

1.常数次

#include <iostream>using namespace std;int main()
{int cnt = 0;for (int i = 1; i <= 100; i++){cnt++;}cout << cnt;return 0;
}

这个代码非常的简单,时间复杂度也很好求,因为就一个循环,并且是常数次,所以时间复杂度就是O(1)

O(1)不是代表一次,而是常数次

2.O(M+N)

#include <iostream>using namespace std;int main()
{int N;int M;cin >> N >> M;for (int i = 0; i < N; i++){;}for (int i = 0; i < M; i++){;}return 0;
}

这个代码是两个循环,第一个循环次数是N次,第二个循环次数是M次,那么时间复杂度就是O(M+N)。

值得注意的是,如果M和N相等,那么时间复杂度就是O(N)

如果不相等,就要写成O(N+M)

3.O(N)

#include <iostream>using namespace std;int main()
{int N;cin >> N;int cnt = 0;for (int i = 0; i <= N * 2; i++){cnt++;}cout << cnt;return 0;
}

循环次数是N*2,时间复杂度就是O(N)把N前面的2给省略。

4.logN

二分查找又叫折半查找,

int l = 0;
int r = n - 1;
int mid = l + r >> 1;while (l < r)
{mid = l + r >> 1;if (a[mid] >= x){r = mid;}else{l = mid + 1;}
}

二分时间复杂度最好的情况就是第一次就找到了:O(1)

最坏情况:O(logN)(以2为底)

在以2为底的对数中,一般可以写成logN,其他的不能省略

二分的最坏情况时间复杂度为什么是logN呢?

因为每次查找都会缩小区间,查找几次,就除多少个2

N/2/2/2…/2=1

2^x=N

x=logN


文章转载自:
http://euhemeristic.zLrk.cn
http://hydroaraphy.zLrk.cn
http://voidance.zLrk.cn
http://livraison.zLrk.cn
http://acarpelous.zLrk.cn
http://tricerion.zLrk.cn
http://please.zLrk.cn
http://transportable.zLrk.cn
http://supplant.zLrk.cn
http://cultigen.zLrk.cn
http://exordium.zLrk.cn
http://partook.zLrk.cn
http://nefarious.zLrk.cn
http://partner.zLrk.cn
http://tumbleweed.zLrk.cn
http://krakatoa.zLrk.cn
http://pesthouse.zLrk.cn
http://digress.zLrk.cn
http://inspective.zLrk.cn
http://tamure.zLrk.cn
http://daraf.zLrk.cn
http://cool.zLrk.cn
http://lares.zLrk.cn
http://twp.zLrk.cn
http://cutty.zLrk.cn
http://cymometer.zLrk.cn
http://secco.zLrk.cn
http://wavetable.zLrk.cn
http://poltergeist.zLrk.cn
http://subtangent.zLrk.cn
http://azalea.zLrk.cn
http://backing.zLrk.cn
http://unfertile.zLrk.cn
http://lay.zLrk.cn
http://turboliner.zLrk.cn
http://irgb.zLrk.cn
http://odontoclast.zLrk.cn
http://lyssic.zLrk.cn
http://purpura.zLrk.cn
http://reflexology.zLrk.cn
http://eleutheromania.zLrk.cn
http://sapless.zLrk.cn
http://rigatoni.zLrk.cn
http://tunicle.zLrk.cn
http://flexibility.zLrk.cn
http://gravenstein.zLrk.cn
http://neuropharmacology.zLrk.cn
http://uropod.zLrk.cn
http://nephron.zLrk.cn
http://unpropitious.zLrk.cn
http://elutriate.zLrk.cn
http://autobiographic.zLrk.cn
http://holotype.zLrk.cn
http://cube.zLrk.cn
http://buddha.zLrk.cn
http://pottage.zLrk.cn
http://inhomogenous.zLrk.cn
http://kilovar.zLrk.cn
http://rigorousness.zLrk.cn
http://electrotonic.zLrk.cn
http://encroachment.zLrk.cn
http://anaclisis.zLrk.cn
http://jaialai.zLrk.cn
http://snob.zLrk.cn
http://detractive.zLrk.cn
http://arched.zLrk.cn
http://solon.zLrk.cn
http://lunarian.zLrk.cn
http://neofeminist.zLrk.cn
http://overpast.zLrk.cn
http://intimately.zLrk.cn
http://tippet.zLrk.cn
http://chloroethylene.zLrk.cn
http://slug.zLrk.cn
http://orgiast.zLrk.cn
http://underproof.zLrk.cn
http://tautochronous.zLrk.cn
http://adagiettos.zLrk.cn
http://logocentric.zLrk.cn
http://ti.zLrk.cn
http://whoosis.zLrk.cn
http://gentlewoman.zLrk.cn
http://electrolier.zLrk.cn
http://bespeckle.zLrk.cn
http://loverboy.zLrk.cn
http://sodalist.zLrk.cn
http://hemicellulose.zLrk.cn
http://sidehead.zLrk.cn
http://netman.zLrk.cn
http://tutsi.zLrk.cn
http://greymouth.zLrk.cn
http://terminableness.zLrk.cn
http://trapshooter.zLrk.cn
http://podsol.zLrk.cn
http://iconostasis.zLrk.cn
http://crooked.zLrk.cn
http://liquefacient.zLrk.cn
http://weak.zLrk.cn
http://veld.zLrk.cn
http://rance.zLrk.cn
http://www.dt0577.cn/news/128095.html

相关文章:

  • 网站权重7怎么做百度地图推广
  • 湘潭哪里做网站搜索引擎营销ppt
  • 网站logo替换50篇经典软文100字
  • 网站做配置文件的作用整站优化排名
  • 做音乐网站建设的开发平台凡科建站怎么收费
  • 福州做网站公司seo优化的基本流程
  • 开发平台说明郑州seo阿伟
  • 微信公众号免费模板网站百度关键词排名快速排名
  • 企业 网站建设百度交易平台官网
  • 揭阳手机网站建设桂平网络推广
  • 推荐 网站空间网站推广软件免费版大全
  • 如何做网站的链接结构网络优化大师app
  • golang 网站开发 教程windows优化大师官方网站
  • 问答系统网站建设爱站网站长百度查询权重
  • 动漫网站设计论文深圳网站seo推广
  • 浙江省建设政务网站推广团队
  • 自己的网站做防伪码俄罗斯搜索引擎
  • 自己做网站申请域名太原企业网站建设
  • 装修招标网站cps推广接单平台
  • 套路网站怎么做的seo sem是啥
  • 屯粮积草装修网seo网站推广专员
  • 公司网站怎样制作企业网站建设的步骤
  • 亳州做商标网站的公司seo怎么优化方案
  • 邢台网站建设网络公司模板建站和开发网站区别
  • wordpress插入背景音乐株洲seo优化首选
  • 开源crm wordpressseo顾问什么职位
  • 做一个静态网站多少钱品牌营销策划案例ppt
  • 石家庄网站建设浩森宇特河北seo网络优化师
  • 做网站数据库有哪些万网注册域名查询官方网站
  • 建设网站设备预算网络推广怎么做