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

河北网站建设团队市场推广方案范文

河北网站建设团队,市场推广方案范文,做类似淘宝的网站开发需要什么,做电影网站用什么软件. - 力扣(LeetCode)给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。 你必须设计并实现时间复杂度为 O(n) 的算法解决此问…

. - 力扣(LeetCode)给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。

请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。

你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。

示例 1:

输入: [3,2,1,5,6,4], k = 2
输出: 5

示例 2:

输入: [3,2,3,1,2,4,5,5,6], k = 4
输出: 4

提示:

  • 1 <= k <= nums.length <= 105
  • -104 <= nums[i] <= 104

思路1:基于堆排序的选择方法

排序 - - - 选择排序(简单选择、堆排序)_c#排序中选择排序中的dui排序-CSDN博客

「调整」

        父节点都大于或小于子结点

// 以root为根,调整大根堆void heapAdjust(vector<int>& nums, int root, int heapSize){int i = root;  // i保存根节点下标for(int j = i*2 + 1; j < heapSize; j = i*2+1){// j保存孩子中最大值下标if(j < heapSize - 1 && nums[j] < nums[j+1]){j++;}if(nums[i] >= nums[j]){break;}else{swap(nums[i], nums[j]);i = j;}}}

「建堆」

        将排序码k1,k2,k3,…,kn表示成一棵完全二叉树,然后从第 n/2个排序码(即树的最后一个非终端结点)开始筛选,使由该结点作根结点组成的子二叉树符合堆的定义,然后从第 n/2-1 个排序码重复刚才操作,直到第一个排序码止。

void buildHeap(vector<int>&nums, int heapSize){for(int i = heapSize / 2; i >= 0; i--){heapAdjust(nums, i, heapSize);}}

「删除」

        将堆中第一个结点(二叉树根结点)和最后一个结点的数据进行交换(k1与kn),再将k1~kn-1重新建堆,然后k1和kn-1交换,再将k1~kn-2重新建堆,然后k1和kn-2交换,如此重复下去,每次重新建堆的元素个数不断减1,直到重新建堆的元素个数仅剩一个为止。这时堆排序已经完成,则排序码k1,k2,k3,…,kn已排成一个有序序列。

class Solution {
private:// 以root为根,调整大根堆void heapAdjust(vector<int>& nums, int root, int heapSize){int i = root;  // i保存根节点下标for(int j = i*2 + 1; j < heapSize; j = i*2+1){// j保存孩子中最大值下标if(j < heapSize - 1 && nums[j] < nums[j+1]){j++;}if(nums[i] >= nums[j]){break; // 因为从叶子节点向上调节,所以没有节点交换,其子树也不许变化}else{swap(nums[i], nums[j]);i = j; // j节点调整,其子树也需要调整}}}void buildHeap(vector<int>&nums, int heapSize){for(int i = heapSize / 2; i >= 0; i--){heapAdjust(nums, i, heapSize);}}public:int findKthLargest(vector<int>& nums, int k) {int heapSize = nums.size();buildHeap(nums, heapSize);// 第k大数倒数for(int i = nums.size() - 1; i > nums.size() - k; --i){swap(nums[0],nums[i]);--heapSize;heapAdjust(nums, 0, heapSize);}return nums[0];}
};

思路2:基于快速排序的选择方法

排序 - - - 交换排序(快速排序、冒泡排序)-CSDN博客

class Solution {
private:int partition(vector<int>&nums, int l, int r){int key = nums[l];while(l < r){while(l < r && nums[r] >= key) r--;nums[l] = nums[r];while(l < r && nums[l] <= key) l++;nums[r] = nums[l];}nums[l] = key;return l;}int quickSelect(vector<int>& nums, int l, int r, int k){int index = partition(nums, l, r);if(index == k)return nums[k];elsereturn index < k ? quickSelect(nums, index + 1, r, k)  // index数小于第k数则在index右边查找: quickSelect(nums, l, index - 1, k); // index数大于第k数则在index左边查找}public:int findKthLargest(vector<int>& nums, int k) {return quickSelect(nums, 0, nums.size() - 1, nums.size() - k); // 返回倒数k位置数}
};

http://www.tj-hxxt.cn/news/59140.html

相关文章:

  • 个体户做网站有用吗宁波seo关键词优化教程
  • 免费微信网站制作免费域名注册平台有哪些
  • 唐山软件开发公司排名seo关键词优化软件手机
  • 哪家网站建设服务好啊重庆白云seo整站优化
  • 西昌市住房与城乡建设厅网站阿里指数查询手机版
  • php+mysql网站开发全程实例pdfseo优化课程
  • 找公司的软件有哪些优速网站建设优化seo
  • b2b网站模板免费下载企业网络的组网方案
  • wordpress网站关键词三只松鼠网络营销策略
  • wordpress二级域名做站群seo的优点和缺点
  • 昆山广告设计公司山东seo首页关键词优化
  • 固镇县住房和城乡建设局网站google官网入口手机版
  • 网站扫描怎么做企业营销培训课程
  • 项目网络由箭线和节点构成网站排名优化的技巧
  • 前端是什么工作seo营销课程培训
  • 下载wix做的网站百度推广登陆入口官网
  • 征婚网站做原油百度资讯指数
  • 手机网站注意哪些问题吗群排名优化软件
  • 张家港外贸型网站制作百度url提交
  • 自由建网站的网络程序百度热搜广告位
  • 购物车功能网站怎么做的正能量网站地址链接免费
  • 做网站背景图片找培训机构的app
  • ui设计师mike个人网站广告联盟哪个比较好
  • 做网站用哪种语言好网站开发费用
  • 想找私人做网站网络营销手段有哪些方式
  • 网站建设书百度官网登录入口手机版
  • 建设一个网站需要什么人员廊坊seo推广
  • 网站建设专业网站设计公司物格网本地推广平台
  • 昆明app外包seo入口
  • 手机网站打不开被拦截怎么办网站排名软件推荐