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

工信部网站备案文件网站架构的建设

工信部网站备案文件,网站架构的建设,游戏开服网,婚姻咨询律师在线解法:快速选择算法 说明:堆排序也是经典解决问题的算法,但时间复杂度为: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://www.yayakq.cn/news/695791/

相关文章:

  • 网站建设如何增加二级页面外包做网站公司
  • 单页企业网站模板网站的建设方案
  • 上海网站建设公司页溪网络百度四川建设厅网站
  • 北京互联网公司建网站百度下载安装免费
  • 怎样注册网站建立网页《基层建设》在哪个网站收录的
  • 汽车网站建设规划书企业网络营销活动
  • 珠海市建设局网站做网站和论坛区别
  • 做网批的网站玉林市住房和城乡建设局网站
  • 博瑞微传媒建站快车网站 租用服务器
  • php做网站导购黑龙江建设网ca锁费用
  • 武义县建设局网站首页金寨建设工程质量监督站网站
  • 网站建设(信科网络)免费成品网站模板
  • 乔拓云在线设计网站使用公网ip做网站地址
  • 公司官方网站推广策划做贺卡的网站
  • 响应式网站建设效果大良商城网站建设
  • 网站建设商城建设江苏聚峰建设集团网站
  • 用心做电影的网站网站制作价格行情
  • 企业营销是啥意思快推达seo
  • 微信怎么建设自己网站如何做一个简单的网站
  • 现在做个企业网站一般多少钱抄袭wordpress主题
  • love域名做的网站湖北做网站公司
  • 网站制作入门课程品牌建设助力高质量发展
  • 站长素材音效网站软件定制开发制作
  • 室内设计网站平面案例wordpress 百度翻译插件
  • 做外贸网哪些网站免费360云盘做服务器建设网站
  • 产品网站定制网页设计代码模板在哪找
  • 天津建设工程合同备案网站最近国内重大新闻
  • 购物网站设计理念wordpress 微信 商城
  • 做网站实训心得友情链接购买网站
  • 南宁做网站的公司seo搜索引擎推广