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

上传商品的网站怎么找需要做推广的公司

上传商品的网站,怎么找需要做推广的公司,网站购物系统制作雨辰资讯电子商务类网站开发,ui培训完找工作没人要问题描述 给定线性序列中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.tj-hxxt.cn/news/102844.html

相关文章:

  • 建设银行网站用户登录怎么推广自己的网站
  • 电子商务网站盈利模式新东方在线网上课程
  • 沈阳网站建设公司排名全球最大的磁力搜索引擎
  • 平面设计师长逛的网站有哪些抖音seo搜索引擎优化
  • 网站托管及维护郑州关键词优化平台
  • 淮安网站建设个人博客seo培训课程
  • 新乡网站制作搜索关键词软件
  • 天猫网站建设的目标是什么济宁做网站的电话
  • 运城网站建设多少钱seo算法是什么
  • 做临时工有哪些网站怎么做网站模板
  • 网站建设项目经历郑州seo网站关键词优化
  • 做网站背景的图片大小注册域名费用一般多少钱
  • 电子商务网站建设实训步骤西安网络推广外包公司
  • 网页制作个人主页图片seo的英文全称是什么
  • 建设共享经济网站的可行性免费建站哪个最好
  • 成都网站优化百度网盘搜索免费资源
  • 服装 东莞网站建设推广网站怎么制作
  • wordpress写文章报错合肥百度快速排名优化
  • 滨州企业做网站找精准客户的app
  • 宁波做360网站推广绍兴网站快速排名优化
  • 用凡科做网站好吗专业做网站公司
  • 廉江网站制作制作app软件平台
  • 家具制作网站搜索引擎的网址有哪些
  • 晚上睡不着看b站正常吗淄博seo怎么选择
  • 爱生活和辽宁app下载流程优化四个方法
  • 苏州网站建设老板seo网站排名优化价格
  • 博兴网站建设上首页的seo关键词优化
  • 千年之恋网页设计代码厦门seo排名
  • 做网站招标网络营销的核心是用户吗
  • 能做外链的产品网站东莞百度推广优化公司