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

建设将网站加入受信网站再试廊坊网站排名优化公司哪家好

建设将网站加入受信网站再试,廊坊网站排名优化公司哪家好,成都专业网站建设价格低,深圳建站软件问题描述 给定线性序列中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.dtcms.com/wzjs/388447.html

相关文章:

  • 做电影网站服务器强力搜索引擎
  • 阳泉推广型网站开发电子网址怎么创建
  • 档案网站建设百度短链接在线生成
  • 两学一做材料上哪个网站找赣州seo优化
  • [ 1500元做网站_验收满意再付款! ]_沛县网络公司整合营销理论
  • 自适应网站的缺点友情链接的英文
  • 济宁哪里有做网站的今天国际新闻最新消息10条
  • 短视频营销经典案例淘宝关键词怎么优化
  • 陕西住房建设厅官方网站手机百度2020最新版
  • 临沂网站建设公司招聘站长网
  • 网站做动态还是静态站长工具友链查询
  • 学做网站快吗生活中的网络营销有哪些
  • 免费ai写作网站3000字线上运营推广方案
  • wordpress 优酷淘宝关键词优化怎么弄
  • the author wordpress石家庄关键词优化软件
  • 论述电子商务网站建设的流程关键词排名监控
  • 让别人做网站应注意什么免费网站建站页面
  • 视频类网站如何做缓存百度爱采购怎么推广
  • 青浦做网站的公司淘宝代运营靠谱吗
  • 旅游网站哪个做的好分析网站
  • 做网站的公司怎么做业务百度排行
  • 网站单页站群搜索引擎优化的概念
  • 大学生做社交网站百度登录个人中心官网
  • 莆田专业建站公司杭州网站排名提升
  • 网站文字很少怎么做优化域名检测查询
  • 自做跨境电商网站收款东营网站建设哪家更好
  • 做积分商城网站上海互联网公司排名
  • 网站后台管理进入郑州seo公司哪家好
  • 侠客推 网站建设企业网络营销方案策划
  • 深圳 网站建设培训班百度一下你就知道