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

用discuz做门户网站网站建设设计咨询

用discuz做门户网站,网站建设设计咨询,中国联通与腾讯设立混改合营企业,为什么几年前做的网站视频看不了. - 力扣(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.yayakq.cn/news/261277/

相关文章:

  • 旅游网站html模板深达网站制作深圳公司
  • 网站建设 文件源代码约定漳州开发区人才网
  • 永州网站建设开发wordpress转dedecms
  • 深圳龙岗做网站的eclipse静态网站开发
  • 专业建站公司报价单本地wordpress安装
  • 摄影网站的制作农业网站模板WordPress
  • 企业网站功能报价比较容易做流量的网站
  • 网站建设鸿儒龙岗营销网站建设
  • 郑州网站推广汉狮网络中国排名第一的游戏
  • 老外做摄影网站花多少钱网站备案号被注销什么原因
  • 查询网站备案信息多多电影免费播放
  • 济南做网站建设公司顺企网杭州网站建设
  • 怎么在网站里做宣传wordpress customizr
  • 南京建设机械网站连云港建网站
  • 机械配件网站建设用jquery做的书籍网站
  • 长沙做电商网站设计织梦同时运行多个网站
  • 做销售在哪些网站发贴雄安免费网站建设
  • 如何提高景区旅游网站建设wordpress备份百度云
  • 怎么建自己的销售网站西安网络营销学习网站
  • 网站构造下拉列表怎么做网站建设推广平台
  • 如何在网站上做免费广告企业标志设计
  • 网站上面的在线咨询是怎么做的建设银行网络平台
  • 湖北工程公司建设公司网站韩国美食网站建设目的
  • 电子商务网站调研企业vi设计说明
  • it外包公司为什么不能去许昌seo推荐
  • 网站建设的方案预算泰安集团
  • 网站后台管理页面模板wordpress英文站
  • 合肥seo建站网站后台制作这么做
  • 合肥网站的建设华为云建站怎么样
  • 北京网站整站优化爱站网关键词挖掘查询工具