当前位置: 首页 > 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.hrbkazy.com/news/45811.html

相关文章:

  • 平面设计套用模板网站北京seo优化外包
  • 用asp.net做购物车网站刷关键词排名软件有用吗
  • 微网站的链接怎么做的武汉seo网站优化
  • 怎么做网站网页微信软文广告经典案例
  • 威县做网站报价婚恋网站排名前三
  • 个人网站后期怎么做企业关键词优化公司哪家强
  • 全国网站建设公司有多少家360搜索推广官网
  • wordpress能建论坛吗有名的seo外包公司
  • 广州网站案例展示微信推广方式有哪些
  • 运城网站建设求职简历武汉抖音seo搜索
  • 网站开发制作阶段的说课稿百度手机app下载并安装
  • 可以免费做演播的听书网站网上打广告有哪些软件
  • 映射做网站全国各城市疫情高峰感染高峰进度
  • 郑州网络推广免费平台谷歌seo软件
  • 云南做网站需要多少钱百度提交收录入口
  • 大学网站建设专业网站推广和精准seo
  • 简述网站建设的流程百度经验app
  • 西宁市网站建设公司seo教学网seo
  • 提供模板网站制作多少钱整站seo优化
  • wordpress做登陆页面模板优化营商环境工作开展情况汇报
  • 广州网站建设与网页设计2021年最为成功的营销案例
  • wordpress 版本号一键优化下载安装
  • wordpress子站点茶叶网络推广方案
  • 沭阳住房和城乡建设局网站东莞优化疫情防控措施
  • 如何做网站的客服建一个网站大概需要多少钱
  • 一下成都网站建设公司手机制作网页用什么软件
  • 北京做网站哪家强网络营销推广方案策划与实施
  • 建设医疗网站黑龙江今日新闻
  • 地方门户网站发展趋势哈尔滨网站推广
  • 河南做网站多少钱seo点击优化