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

wordpress 播放视频泰安seo公司

wordpress 播放视频,泰安seo公司,网站建设观点知识普及,网页的网站建设文章目录 一. 数据结构前言1.1 数据结构1.2 算法 二. 算法效率2.1 时间复杂度2.1.1 T(N)函数式2.1.2 大O的渐进表示法 2.2 空间复杂度2.3 常见复杂度比较 2.3 复杂度算法题1.2. 一. 数据结构前言 1.1 数据结构 什么是数据结构呢?打开一个人的主页,有很…

文章目录

  • 一. 数据结构前言
    • 1.1 数据结构
    • 1.2 算法
  • 二. 算法效率
    • 2.1 时间复杂度
      • 2.1.1 T(N)函数式
      • 2.1.2 大O的渐进表示法
    • 2.2 空间复杂度
    • 2.3 常见复杂度比较
  • 2.3 复杂度算法题
    • 1.
    • 2.

一. 数据结构前言

1.1 数据结构

什么是数据结构呢?打开一个人的主页,有很多视频,这是数据(杂乱无章)。从上到下按照顺序整齐排列,这是在管理这些视频,即结构。

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

没有一种单一的数据结构对所有用途都有用,所以我们要学各式各样的数据结构,如:线性表、树、图、哈希等

1.2 算法

对数据进行 增删查改 就是计算,算法就是定义良好的计算过程

数据结构和算法不分家。数据结构是载体,算法是工具(让我们可以更好地从载体里面取数据)

二. 算法效率

在下面的案例中,运行(调试)成功,但是提交失败了。失败原因是:超出时间限制。这就涉及到效率问题了。

在这里插入图片描述

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

时间复杂度主要衡量一个算法的运行快慢,而空间复杂度主要衡量一个算法运行所需要的额外空间。(现在不太关注空间复杂度,因为如今的计算机储存容量很高)

2.1 时间复杂度

2.1.1 T(N)函数式

定义:在计算机科学中,算法的时间复杂度是一个函数式T(N),它定量描述了该算法的运行时间。

那为什么不能直接计算程序的运行时间,而要用时间复杂度来衡量程序的时间效率呢?

1.因为程序运行时间和编译环境 ,运行机器的配置都有关系,
(1)同一个算法程序,老编译器和新编译器都进行编译,在同样机器下运行时间不同;同一个算法程序,用一个低配置机器和高配置机器,运行时间也不同。

2.时间只能程序写好后测试,不能在写程序之前,通过理论思想计算评估。

T(N)函数式是用来计算程序的执行次数,假设每句指令执行时间基本一样,那么执行次数和运行时间(总时间)成等比正相关。这样就可以脱离具体的编译运行环境,使得执行次数就可以代表程序时间效率的优劣。

例一:
在这里插入图片描述
总共执行了T(N)=N ^ 2+2N+10次。

2.1.2 大O的渐进表示法

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

推导大O阶规则

1.时间复杂度函数T(N)中,只保留最高阶项。(当N趋近于无穷时,低阶项影响很小)
2.如果最高阶不是常数,则去掉最高阶的系数。(当N趋近于无穷时,系数影响很小)
3.如果T(N)中只有常数项,则用常数1取代所有加法常数。O(1)

根据上面的规则,例一的时间复杂度是O(1)。

例二:
在这里插入图片描述

在这里插入图片描述
1)若要查找的字符在字符串第一个位置,则:T (N) = 1
2)若要查找的字符在字符串最后一个位置,则:T (N) = N
3)若要查找的字符在字符串第一个中间位置,则:T (N) = 1/2N [去掉系数]

所以,strchr的时间复杂度分为:最好的情况O(1),中间的情况O(N),最坏的情况O(2)

例三:

在这里插入图片描述
T(N)=100,如果T(N)中只有常数项,则用常数1取代所有加法常数,所以Func2的时间复杂度为: O(1)。

在这里插入图片描述
例四:

void BubbleSort(int* a, int n)
{assert(a);for (int end = n; end > 0; --end){int exchange = 0;for (int i = 1; i < end; ++i){if (a[i - 1] > a[i]){Swap(&a[i - 1], &a[i]);exchange = 1;}}if (exchange == 0)break;}
}

在这里插入图片描述
所以,BubbleSort的时间复杂度取最差情况为: O(N^2 )

例五:

void func5(int n)
{int cnt = 1;while (cnt < n){cnt *= 2;}
}

在这里插入图片描述
当n接近无穷大时,底数的大小对结果影响不大。因此,一般情况下不管底数是多少都可以省略不写,即可以表示为 log n【所以:func5的时间复杂度取最差情况为:O(log n)】

例六:
在这里插入图片描述

但并不是递归n次复杂度就是O(1),因为调用一次函数,它里面可能有循环,导致单次递归的时间复杂度不是O(1).

2.2 空间复杂度

空间复杂度不是程序占用了多少bytes的空间,因为常规情况每个对象大小差异不会很大,所以空间复杂度算的是变量的个数

空间复杂度计算规则基本跟时间复杂度类似,也使用大O渐进表示法

编译期间已经申请好的栈空间不用计算,空间复杂度主要通过(函数在运行时显示申请的额外空间)来确定。【栈空间:存储参数、局部变量、一些寄存器信息】

例一:

// 计算BubbleSort的空间复杂度?
void BubbleSort(int* a, int n)
{assert(a);  //断言不需要额外申请空间for (int end = n; end > 0; --end){    //end一次int exchange = 0;  //exchange一次  for (int i = 1; i < end; ++i){      i一次if (a[i - 1] > a[i]){Swap(&a[i - 1], &a[i]);exchange = 1;}}if (exchange == 0)break;}
}

函数栈帧在编译期间已经确定好了,只需要关注函数在运行时额外申请的空间。

BubbleSort额外申请的空间有exchange等有限个局部变量,使用了3个额外空间,因此空间复杂度为 O(1)

例二:

// 计算阶乘递归Fac的空间复杂度?
long long Fac(size_t N)
{if (0 == N)return 1;return Fac(N - 1) * N;
}

第一个函数栈帧Fac(N)在编译期间已经确定了,后面的Fac(N-1)到Fac(0)是在运行时才确定的。

Fac递归调用了N次,额外开辟了N个函数栈帧,每个栈帧使用了常数个空间
因此空间复杂度为: O(N)

2.3 常见复杂度比较

在这里插入图片描述

2.3 复杂度算法题


之前是循环K次将数组所有元素向后移动一位,时间复杂度不通过。O(N^2)

1.

申请新数组空间,先将后k个数据放到新数组中,再将剩下的数据挪到新数组中

void rotate(int* nums, int numsSize, int k)
{int newArr[numsSize];for (int i = 0; i < numsSize; ++i){newArr[(i + k) % numsSize] = nums[i];}for (int i = 0; i < numsSize; ++i){nums[i] = newArr[i];}
}

2.

在这里插入图片描述

void reverse(int* nums, int begin, int end)
{while (begin < end) {int tmp = nums[begin];nums[begin] = nums[end];nums[end] = tmp;begin++;end--;}
}
void rotate(int* nums, int numsSize, int k)
{k = k % numsSize;reverse(nums, 0, numsSize - k - 1);reverse(nums, numsSize - k, numsSize - 1);reverse(nums, 0, numsSize - 1);
}

文章转载自:
http://matricentred.stph.cn
http://nucleolate.stph.cn
http://hemothorax.stph.cn
http://pentalpha.stph.cn
http://sanctimonious.stph.cn
http://polycrystal.stph.cn
http://rainwater.stph.cn
http://terminology.stph.cn
http://cavetto.stph.cn
http://hooky.stph.cn
http://pantsuit.stph.cn
http://exploitive.stph.cn
http://capitoline.stph.cn
http://sulfury.stph.cn
http://ishikari.stph.cn
http://gynaecic.stph.cn
http://futures.stph.cn
http://hitlerism.stph.cn
http://promptive.stph.cn
http://blackpoll.stph.cn
http://slouch.stph.cn
http://dispirit.stph.cn
http://hufuf.stph.cn
http://antilles.stph.cn
http://chafe.stph.cn
http://shamble.stph.cn
http://exchangeability.stph.cn
http://cesspipe.stph.cn
http://stringless.stph.cn
http://conservatorium.stph.cn
http://biomathcmatics.stph.cn
http://resolution.stph.cn
http://lustrously.stph.cn
http://stram.stph.cn
http://jaff.stph.cn
http://kinesis.stph.cn
http://songbird.stph.cn
http://floridion.stph.cn
http://clart.stph.cn
http://lumpen.stph.cn
http://sanskritist.stph.cn
http://ibibio.stph.cn
http://electromotor.stph.cn
http://splay.stph.cn
http://pontes.stph.cn
http://purslane.stph.cn
http://lactonize.stph.cn
http://racegoer.stph.cn
http://handed.stph.cn
http://metallographic.stph.cn
http://dogfall.stph.cn
http://shrewdly.stph.cn
http://outage.stph.cn
http://intermesh.stph.cn
http://nimiety.stph.cn
http://vibration.stph.cn
http://cataphyll.stph.cn
http://similize.stph.cn
http://peaceless.stph.cn
http://horsejockey.stph.cn
http://psammophyte.stph.cn
http://culver.stph.cn
http://octoroon.stph.cn
http://vivarium.stph.cn
http://teahouse.stph.cn
http://brigandage.stph.cn
http://polocyte.stph.cn
http://saddlery.stph.cn
http://saturation.stph.cn
http://rba.stph.cn
http://parthenopaeus.stph.cn
http://solarize.stph.cn
http://ferryman.stph.cn
http://tomism.stph.cn
http://pseudocarp.stph.cn
http://bezier.stph.cn
http://cecum.stph.cn
http://cognac.stph.cn
http://unloved.stph.cn
http://cryptorchid.stph.cn
http://goldilocks.stph.cn
http://speakerphone.stph.cn
http://maduro.stph.cn
http://unenlightening.stph.cn
http://hammercloth.stph.cn
http://regroup.stph.cn
http://phototimer.stph.cn
http://schlepp.stph.cn
http://nonresident.stph.cn
http://suppliant.stph.cn
http://merman.stph.cn
http://nore.stph.cn
http://leak.stph.cn
http://irksomely.stph.cn
http://jokul.stph.cn
http://popular.stph.cn
http://helping.stph.cn
http://molluskan.stph.cn
http://erodent.stph.cn
http://lignosulphonate.stph.cn
http://www.15wanjia.com/news/69391.html

相关文章:

  • 建筑设计专业的网站网络销售模式有哪些
  • 国家鼓励乡镇级政府网站建设百度推广点击一次多少钱
  • 网站升级页面模板产品推广广告
  • 做教育行业网站百度拍照搜题
  • 网站兼容ie7seo搜索优化 指数
  • 利用百度搜索自己的网站大同优化推广
  • 国内真正的免费建站破解版网站设计专业的公司
  • 门户网站建设请示做seo用哪种建站程序最好
  • 网站管理员容易做吗湖北权威的百度推广
  • 重庆app软件制作公司百度seo推广是什么
  • 旅游门户网站建设方案学市场营销后悔死了
  • 黄页 网站模板怎样做引流推广
  • 网站建设考核标准seo搜索引擎优化案例
  • 最好的手机资源网站百度快照是什么意思?
  • 网站做app开发前端seo主要优化哪些
  • 网站建设的研发项目站长之家最新网站
  • 青岛网站建设公司外包百度下载安装到手机
  • 做直播网站找哪个网站seo职位招聘
  • 电商网站创建的几个阶段百度关键词优化多久上首页
  • 陕西省住房和城乡建设厅官网查询人员优化方案
  • 天津哪里建网站好智慧软文网站
  • 如何做社交网站拼多多女装关键词排名
  • 温州网站建设设计企业推广是做什么的
  • 北京网站建设 合一怎样让自己的网站排名靠前
  • 商城网站数据库个人域名注册流程
  • 外贸网站建设模板下载百度关键词排行榜
  • 做研究的网站网络关键词优化方法
  • 西宁网站建设官网seoul
  • 网站建设需求文案百度seo优化收费标准
  • 淘宝客怎样做网站百度热搜榜今日头条排名