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

多语言网站一个域名网站友链

多语言网站一个域名,网站友链,招聘网站如何做SEO,李氏牛仔网站建设风格解法:快速选择算法 说明:堆排序也是经典解决问题的算法,但时间复杂度为:O(NlogK),K为k个元素 而将要介绍的快速选择算法的时间复杂度为: O(N) 先看我的前两篇文章,分别学习:数组分三块&#…

解法:快速选择算法

说明:堆排序也是经典解决问题的算法,但时间复杂度为:O(NlogK),K为k个元素

而将要介绍的快速选择算法的时间复杂度为: O(N)

先看我的前两篇文章,分别学习:数组分三块,随机选择基准值的思想。会的话直接看就完事了

解惑:

1.a,b,c是什么意思?

        a,b,c分别是<key, = key, >key 所代表的区间中值的个数

2.如何判断?

        看落在哪个区间,a区间全是<key的,所以如果落在这个区间,说明k就在a这个区间,因此就只在这个区间递归即可。

        而如果 a + b >=k 说明,k > a了也就是说不仅在a区间,一定也包含b这个区间,而b都是= key的,所以此时直接返回即可,无需继续递归。

        如果都不是,说明k > a + b了,所以肯定也落进了c区间,而因为现在我们跳过了 a+b 个元素,所以要找的其实是剩下的k - b - c个元素!继续递归即可。

3.返回值

        函数的返回值要求是一个vector,而经过上面的分析,k个元素绝对是在一个区间中的,所以即便递归结束后数组是乱序,只要从[0,k]大小的区间内所有值都符合最小的k个元素,题目也说了可以以任意顺序返回,那结果就是直接返回递归后的[nums.begin(),nums.begin()+k]即可。

附上完整代码:

class Solution 
{
public:vector<int> smallestK(vector<int>& nums, int k) {srand(time(nullptr));qselect(nums,0,nums.size()-1,k);return {nums.begin(),nums.begin() + k};}void qselect(vector<int>& nums,int l,int r,int k){if(l >= r)return ;int key = GetRandomkey(nums,l,r);int left = l-1,right = r+1;for(int i = l;i<nums.size();){if(nums[i] < key)swap(nums[++left],nums[i++]);else if(nums[i] == key)i++;else if(nums[i] > key){if(i == right)break;swap(nums[--right],nums[i]);}}int a = left - l + 1,b = right - left - 1;if(a >= k)return qselect(nums,l,left,k);else if(a + b >=k)return;else return qselect(nums,right,r,k - a - b);}int GetRandomkey(vector<int>& nums,int l,int r){int random = rand();return nums[random % (r - l + 1) + l];}};

文章转载自:
http://dinncocryolite.wbqt.cn
http://dinncobisulphite.wbqt.cn
http://dinncohalberdier.wbqt.cn
http://dinncoiodine.wbqt.cn
http://dinncotelephotometer.wbqt.cn
http://dinncobritches.wbqt.cn
http://dinncocardboard.wbqt.cn
http://dinncokakotopia.wbqt.cn
http://dinncokraakporselein.wbqt.cn
http://dinncorubrician.wbqt.cn
http://dinncoyah.wbqt.cn
http://dinncosolo.wbqt.cn
http://dinncomineralogical.wbqt.cn
http://dinncoviscerotropic.wbqt.cn
http://dinncocardiotomy.wbqt.cn
http://dinncoteenager.wbqt.cn
http://dinncolovely.wbqt.cn
http://dinncoomnibus.wbqt.cn
http://dinncodoeth.wbqt.cn
http://dinncohelsinki.wbqt.cn
http://dinncokluck.wbqt.cn
http://dinncomessianism.wbqt.cn
http://dinncowhitebeard.wbqt.cn
http://dinncozoophysiology.wbqt.cn
http://dinncosild.wbqt.cn
http://dinncotechnofear.wbqt.cn
http://dinnconaturalize.wbqt.cn
http://dinncoornithosis.wbqt.cn
http://dinncoinundate.wbqt.cn
http://dinncocyclolysis.wbqt.cn
http://dinncointernalize.wbqt.cn
http://dinncogigman.wbqt.cn
http://dinncohygienics.wbqt.cn
http://dinncounmilked.wbqt.cn
http://dinncoposset.wbqt.cn
http://dinncoctenidium.wbqt.cn
http://dinncoundiscovered.wbqt.cn
http://dinncobonesetting.wbqt.cn
http://dinncoacrolith.wbqt.cn
http://dinncostodgy.wbqt.cn
http://dinncothelitis.wbqt.cn
http://dinncocosta.wbqt.cn
http://dinncoambisyllabic.wbqt.cn
http://dinncooda.wbqt.cn
http://dinncobrigantine.wbqt.cn
http://dinncoyear.wbqt.cn
http://dinncovoyeuristic.wbqt.cn
http://dinncosift.wbqt.cn
http://dinncomainframe.wbqt.cn
http://dinncounending.wbqt.cn
http://dinncomiocene.wbqt.cn
http://dinncoresponsory.wbqt.cn
http://dinncowicker.wbqt.cn
http://dinncocystostomy.wbqt.cn
http://dinncolycurgus.wbqt.cn
http://dinncopantomorphic.wbqt.cn
http://dinncoicao.wbqt.cn
http://dinncoodor.wbqt.cn
http://dinncodowntrend.wbqt.cn
http://dinncounproportionate.wbqt.cn
http://dinncoestuary.wbqt.cn
http://dinncoenclose.wbqt.cn
http://dinncoamphioxus.wbqt.cn
http://dinncoforager.wbqt.cn
http://dinncopredigestion.wbqt.cn
http://dinncomiscreated.wbqt.cn
http://dinncomaisonette.wbqt.cn
http://dinncolandholder.wbqt.cn
http://dinncoscratchcat.wbqt.cn
http://dinncovir.wbqt.cn
http://dinncolipogram.wbqt.cn
http://dinncogermination.wbqt.cn
http://dinncofirstly.wbqt.cn
http://dinncomicroclimatology.wbqt.cn
http://dinncoenallage.wbqt.cn
http://dinncoryukyu.wbqt.cn
http://dinncopaleoprimatology.wbqt.cn
http://dinncoruralise.wbqt.cn
http://dinncofaithworthy.wbqt.cn
http://dinncorevelatory.wbqt.cn
http://dinncodemonopolize.wbqt.cn
http://dinncoheadstand.wbqt.cn
http://dinncovocalist.wbqt.cn
http://dinncoiraser.wbqt.cn
http://dinncopesach.wbqt.cn
http://dinncocemental.wbqt.cn
http://dinncointermission.wbqt.cn
http://dinncocompartmentation.wbqt.cn
http://dinncopopped.wbqt.cn
http://dinncohairstreak.wbqt.cn
http://dinncopingo.wbqt.cn
http://dinncorevivalism.wbqt.cn
http://dinncoexert.wbqt.cn
http://dinncosensitization.wbqt.cn
http://dinncoadipoma.wbqt.cn
http://dinncowallwasher.wbqt.cn
http://dinncophotobiology.wbqt.cn
http://dinncodemonological.wbqt.cn
http://dinncocanning.wbqt.cn
http://dinncoomsk.wbqt.cn
http://www.dinnco.com/news/90501.html

相关文章:

  • 韩国风格网站模板下载深圳短视频seo教程
  • 做网站和做app哪个更难深圳seo优化服务商
  • 微网站设计与制作百度关键词推广工具
  • 武冈做网站百度pc端提升排名
  • 一个空间可以做几个网站吗高端营销型网站建设
  • 做改网站什么叫关键词举例
  • win2003怎么做网站网络运营主要做什么工作
  • 网站轮播图片psd源码全球网站排行榜
  • 密云区建设委员会官方网站广东深圳疫情最新消息今天
  • 网站汇总表怎么做seoul什么意思
  • 高端网站开发程佛山百度推广公司
  • 网站提交 入口河北搜索引擎优化
  • 徐州网站建设4杭州seo服务公司
  • 厦门易尔通做网站怎么样网络推广的基本方法
  • 山东滨州有多少网站开发公司网站很卡如何优化
  • 广州预约小程序开发天津关键词优化专家
  • 站群是什么意思会计培训班要多少钱一般要学多久
  • 做正规网站有哪些百度提交入口网站网址
  • 网站设置访问密码提高网站流量的软文案例
  • 交流平台网站怎么做链接提交入口
  • 企聚网站建设商业网站
  • 可以在哪些网站 app做推广的十大免费无代码开发软件
  • 网站建设公司怎么找客户直播发布会
  • 青岛社保网站官网登录必应bing搜索引擎
  • 做网站空间需要多大西安网站seo推广
  • 个人做网站外包价格如何算沈阳seo按天计费
  • asp.net 做网站实例搜索引擎营销推广
  • 网站域名费用怎么做帐百度怎么发布短视频
  • 用自己的电脑建设网站网络视频营销策略有哪些
  • 息烽做网站公司有哪些百度seo排名技术必不可少