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

深圳西乡网站建设营销的目的有哪些

深圳西乡网站建设,营销的目的有哪些,专业苏州网站建设公司,网站建设进度表 免费下载问题描述 给定线性序列中n个元素和一个整数k,1≤k≤n,要求在线性时间中找出这n个元素中第k小的元素 常规思路 常规思路是对序列先排序,落在第k个位置的元素就是第k小的元素。 这种方法的时间复杂度不是线性的,是O(nlogn)的时间…

问题描述

给定线性序列中n个元素和一个整数k,1≤k≤n,要求在线性时间中找出这n个元素中第k小的元素

常规思路

常规思路是对序列先排序,落在第k个位置的元素就是第k小的元素。

这种方法的时间复杂度不是线性的,是O(nlogn)的时间复杂度,使用快排极端情况下甚至会出现O(n^2)的时间复杂度。问题需要在O(n)的时间内完成,故而这种方法不可行

快速排序的时间复杂度可以看这篇文章的最后

分治法解决

在这里插入图片描述

使用分治法解决这个问题,思路就是先将数组一分为二,利用Partition函数,将数组分成左小右大的两部分,然后判断Partition函数返回的中枢ik的关系

  • i<k,第k小在右数组,递归调用自身,在i+1r的区间中找第k-j
  • i>k,第k小在左数组,递归调用自身,在pi的区间中找第k小
  • i==k,当前值就是第k小

递归边界是p=r时,数组只有一个元素,第一小第k小都是该元素

代码

Type RandomizedSelect(Type a[], int p, int r, int k) {if (p == r)return a[p];i = RandomizedPartition(a, p, r);j = i - p + 1;if (k == j)return a[i];else if (k < j)return RandomizedSelect(a, p, i, k);elsereturn RandomizedSelect(a, i + 1, r, k - j);
}
Type RandomizedPartition(Type a[], int p, int r) {i = Random(p, r);//用于生成p到r的随机数swap(a[i], a[p]);//交换a[i]和a[p]return Partition(a, p, r);
}

关于Partition算法,可以看这篇文章中的介绍

由于Partition算法存在的不足,故而这里使用RandomizedPartition算法,随机选择一个元素作为划分基准,效果更好

算法分析

极端情况下,算法的最坏时间复杂度仍是 O ( n 2 ) O(n^2) O(n2),尽管使用RandomizedPartition算法,仍不难保证极端情况的绝对不发生

但可以证明,算法的平均时间复杂度 O ( n ) O(n) O(n)

http://www.ds6.com.cn/news/114053.html

相关文章:

  • 然后建设一个论坛网站我的百度账号
  • 百度开发者大会品牌词优化
  • 涿州市建设局网站网址是多少网络营销是网上销售吗
  • 北京大型商场seo引擎优化外包
  • 萧山做网站公司如何快速网络推广
  • 35互联做网站好吗网站制作推广
  • b2c商城网站建设免费打广告网站
  • 做网站销售电销好做吗500强企业seo服务商
  • 重庆做网站团队企业网站建设价格
  • 怎样看一个网站是谁做的发布友情链接
  • 新手学做网站百度云线上运营推广
  • 全媒体运营师报名入口西安的网络优化公司
  • 今日新闻联播主要内容正规优化公司哪家好
  • 高埗做网站公司深圳网络推广工资
  • 网站建设对图片有哪些要求百度搜索指数
  • 做网站店铺怎样打理网络营销渠道有哪些
  • 99999在线影院狂野大陆北京aso优化
  • 手机网站一键生成app网站设计公司建设网站
  • 政府网站建设 江苏省中国十大互联网公司排名
  • 洛阳做网站短视频剪辑培训班速成
  • 中国b2b网站有哪些网站推广 方法
  • 海口做网站要多少钱seo优化课程
  • 无锡网站建设专家无锡网站制作百度企业官网
  • 注册会计师报名时间北海seo快速排名
  • 四川高速公路建设集团网站seo快速排名优化公司
  • wordpress位置济南网站优化培训
  • 大连有几家做网站的公司百度人气榜排名
  • 做网站毕业论文镇江seo公司
  • 创建.com网站上海网络推广外包公司
  • 长春专业做网站seo营销软件