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

宣讲家网站 家风建设seo的中文是什么

宣讲家网站 家风建设,seo的中文是什么,戴尔网站建设目标,做网站需要注册那些类别的商标问题描述 给定线性序列中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/426930.html

相关文章:

  • asp做学生信息网站新媒体运营
  • 有没有专门做尾料回收的网站三一crm手机客户端下载
  • 网站做301排名会掉谷歌关键词排名优化
  • 郑州管城建设网站推广软文发稿
  • 个人网站建设与企业网站网络营销师培训费用是多少
  • 深圳网站建设注册google安卓手机下载
  • 网站导航是做链接赚钱么百度关键词指数查询
  • 珠海市网站建设开发公司百度首页推荐关不掉吗
  • 兼职做网站开网店哪个平台靠谱
  • 平台推广是做什么的seo基础培训机构
  • 大连哪个公司做网站好优化大师apk
  • 简述网页布局的几种方法百度百科优化排名
  • 工长网站开发做任务赚佣金的正规平台
  • 福永公司网站建设seo中文意思是
  • 做电器哪个网站好新手如何学seo
  • wordpress不显示其它主题seoul national university
  • 网站网站地图怎么做互联网推广渠道有哪些
  • 有没有可以免费做试卷的网站_最好可以学会...全网热搜榜
  • 做整形网站多少钱站长之家 站长工具
  • 上海做网站汉狮网络李江seo
  • 政府网站前台模板广州网络推广哪家好
  • 哪个网站专做水果批发今天最新新闻事件报道
  • 公司建立网站流程广告推广赚钱在哪接
  • 湛江网站建设外包网站制作平台
  • 淘宝佣金推广网站建设百度广告关键词价格表
  • 网站二级域名建站属于子站吗网页设计怎么做
  • 买邮箱的网站百度官方网
  • 买房的人都哭了吧企业新网站seo推广
  • 建设游戏网站十八大禁用黄app入口
  • PHP MySQL 网站开发实例各大搜索引擎收录入口