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

石家庄网络推广优化企业优化推广

石家庄网络推广优化,企业优化推广,网站建设题目,汕头站扩建工程一、前言 算法#xff08;Algorithm#xff09;是指用来操作数据、解决程序问题的一组方法。对于同一个问题#xff0c;使用不同的算法#xff0c;也许最终得到的结果是一样的#xff0c;但在过程中消耗的资源和时间却会有很大的区别 衡量不同算法之间的优劣主要是通过时…一、前言 算法Algorithm是指用来操作数据、解决程序问题的一组方法。对于同一个问题使用不同的算法也许最终得到的结果是一样的但在过程中消耗的资源和时间却会有很大的区别 衡量不同算法之间的优劣主要是通过时间和空间两个维度去考量 时间维度是指执行当前算法所消耗的时间我们通常用「时间复杂度」来描述。空间维度是指执行当前算法需要占用多少内存空间我们通常用「空间复杂度」来描述 通常会遇到一种情况时间和空间维度不能够兼顾需要在两者之间取得一个平衡点是我们需要考虑的 一个算法通常存在最好、平均、最坏三种情况我们一般关注的是最坏情况 最坏情况是算法运行时间的上界对于某些算法来说最坏情况出现的比较频繁也意味着平均情况和最坏情况一样差 二、时间复杂度 时间复杂度是指执行这个算法所需要的计算工作量其复杂度反映了程序执行时间「随输入规模增长而增长的量级」在很大程度上能很好地反映出算法的优劣与否 一个算法花费的时间与算法中语句的「执行次数成正比」执行次数越多花费的时间就越多 算法的复杂度通常用大O符号表述定义为T(n) O(f(n))常见的时间复杂度有O(1)常数型、O(log n)对数型、O(n)线性型、O(nlogn)线性对数型、O(n^2)平方型、O(n^3)立方型、O(n^k)k次方型、O(2^n)指数型如下图所示 ​ 从上述可以看到随着问题规模n的不断增大上述时间复杂度不断增大算法的执行效率越低由小到大排序如下 Ο(1)Ο(log n)Ο(n)Ο(nlog n)Ο(n2)Ο(n3)…Ο(2^n)Ο(n!)注意的是算法复杂度只是描述算法的增长趋势并不能说一个算法一定比另外一个算法高效如果常数项过大的时候也会导致算法的执行时间变长 关于如何计算时间复杂度可以看看如下简单例子 function process(n) {let a 1let b 2let sum a bfor(let i 0; i n; i) {sum i}return sum }该函数算法需要执行的运算次数用输入大小n的函数表示即 T(n) 2 n 1那么时间复杂度为O(n 3)又因为时间复杂度只关注最高数量级且与之系数也没有关系因此上述的时间复杂度为O(n) 又比如下面的例子 function process(n) {let count 0for(let i 0; i n; i){for(let i 0; i n; i){count 1}} }循环里面嵌套循环外面的循环执行一次里面的循环执行n次因此时间复杂度为 O(n*n*1 2) O(n^2) 对于顺序执行的语句总的时间复杂度等于其中最大的时间复杂度如下 function process(n) {let sum 0for(let i 0; i n; i) {sum i}for(let i 0; i n; i){for(let i 0; i n; i){sum 1}}return sum }上述第一部分复杂度为O(n)第二部分复杂度为O(n^2)总复杂度为max(O(n^2), O(n)) O(n^2) 又如下一个例子 function process(n) {let i 1; // ①while (i n) {i i * 2; // ②} }循环语句中以2的倍数来逼近n每次都乘以2。如果用公式表示就是1 * 2 * 2 * 2 … * 2 n也就是说2的x次方小于等于n时会执行循环体记作2^x n于是得出xlogn 因此循环在执行logn次之后便结束因此时间复杂度为O(logn) 同理如果一个O(n)循环里面嵌套O(logn)的循环则时间复杂度为O(nlogn)像O(n^3)无非也就是嵌套了三层O(n)循环 三、空间复杂度 空间复杂度主要指执行算法所需内存的大小用于对程序运行过程中所需要的临时存储空间的度量 除了需要存储空间、指令、常数、变量和输入数据外还包括对数据进行操作的工作单元和存储计算所需信息的辅助空间 下面给出空间复杂度为O(1)的示例如下 let a 1 let b 2 let c 3上述代码的临时空间不会随着n的变化而变化因此空间复杂度为O(1) let arr [] for(i1; in; i){arr.push(i) }上述可以看到随着n的增加数组的占用的内存空间越大 通常来说只要算法不涉及到动态分配的空间以及递归、栈所需的空间空间复杂度通常为O(1)一个一维数组a[n]空间复杂度O(n)二维数组为O(n^2)
http://www.zqtcl.cn/news/789993/

相关文章:

  • 好看的模板网站建设西安网站模板建站
  • 建设网站二级子页打不开广告设计平面设计培训班
  • 网站公司做网站要多少钱新乡
  • 天津谁做网站莱芜人才网招聘网
  • 学做网站的书籍自己做网站 最好的软件
  • 手机网站专题电商入门视频教程免费
  • aspx网站模板制作网页常用的软件有哪些
  • 网站主关键词湖南网站定制
  • 长沙seo网站排名优化公司进入秦皇岛最新规定
  • 企业网站优化平台宝山北京网站建设
  • 给人做代工的网站加盟代理网
  • 网站建设用dw电脑谷歌浏览器打开是2345网址导航
  • 做外贸一般总浏览的网站太原的网站建设公司哪家好
  • 台州建网站公司wordpress 用微信登陆
  • 广州白云网站建设家在深圳业主
  • 呼和浩特网站建设哪家最便宜?携程旅行网网站策划书
  • 网站建设及相关流程北京网站备案域名
  • 汉字叔叔花了多少钱做网站微商城科技
  • 网站代理被抓html网站开发实战
  • 如何建立免费的网站网站copyright写法
  • 官方网站下载12306合肥有没有做网站的单位
  • 甘露园网站建设网站框架图片
  • 做网站怎样赚卖流量石家庄网站建设联系电话
  • wordpress 图片网站本地免费发布信息网站
  • 建设网站和别人公司重名新乡建设招标投标网站
  • 四川省建设厅网站证想开个网站怎样开公司
  • 做机械一般做那个外贸网站电商软件开发费用
  • 网站外链坏处龙岗网站设计信息
  • 郑州网站建设乙汉狮网络搜索优化网络推广
  • Dw做html网站百度推广竞价排名