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

服务器建设网站品牌推广公司

服务器建设网站,品牌推广公司,福州外包seo公司,wordpress 目录权限设置题目 给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。 请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。 你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。 示例 1: 输入: [3,2,1,5,6,4…

题目

给定整数数组 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 <= 10^5
  • -10^4 <= nums[i] <= 10^4

解答

源代码

class Solution {Random rand = new Random();public int findKthLargest(int[] nums, int k) {return quickSelect(nums, k, 0, nums.length - 1);}public int quickSelect(int[] nums, int k, int left, int right) {int index = rand.nextInt(right - left + 1) + left;// 目标值int target = nums[index];// 因为在之后交换元素中,nums[left]的值会被覆盖,所以这里把nums[index]记为nums[left]的值nums[index] = nums[left];int i = left, j = right;while (i < j) {while (i < j && nums[j] <= target) {j--;}nums[i] = nums[j];while (i < j && nums[i] >= target) {i++;}nums[j] = nums[i];}// 此时nums[i]前的元素都比目标值大,nums[i]之后的元素都比目标值小nums[i] = target;if (i == k - 1) {return nums[i];} else if (i < k - 1) {return quickSelect(nums, k, i + 1, right);} else {return quickSelect(nums, k, left, i - 1);}}
}

总结

这道题写得我好痛苦……因为后面的测试案例有极端情况,所以一定要用到随机,又因为用到了随机,所以和排序算法不是完全一样,不能直接进行交换,否则最后相遇的那个数和目标值交换后的数组不一定是合法的(目标值前面都是大于它的数,后面都是小于它的数)。

http://www.khdw.cn/news/19567.html

相关文章:

  • 兰州网站的优化合肥百度快速排名优化
  • dw网站建设关键词在线试听免费
  • 追设计网站今天国际新闻大事
  • 我做的网站不知道网站怎么办搜索引擎关键词的工具
  • 电子商务网站建设与维护的教学建网站一般多少钱
  • 动态网站开发 用什么模板语言企业营销推广方案
  • 用word文档做网站腾讯云域名注册官网
  • 网站项目策划书模板seo推广公司有哪些
  • 做网站用jsp还是html微信搜一搜seo
  • 网站上传视频怎么做口碑营销案例有哪些
  • 黄山网站建设公司上海网络营销
  • 郑志平爱站网创始人宣传页面怎么制作
  • 苏州高端网站设计企业怎样做好销售和客户交流
  • dw网站制作流程发表文章的平台有哪些
  • wordpress begin教程seo权重查询
  • 北京最大的网站建设有限公司公司企业员工培训
  • 齐博企业网站推广公司有哪些公司
  • wordpress需要翻墙吗关键词排名优化工具有用吗
  • 岳阳企业网站定制开发成品网站源码的优化技巧
  • 深圳做app网站制作seo怎么发外链的
  • 如何查网站有无备案举例网络营销的例子
  • 上海网站建设开上海网络排名优化
  • 网站建设贰金手指下拉贰拾网络营销的方式和方法
  • 二维码生成器小程序站长工具seo查询5g5g
  • 爱站网新网址是多少淘宝seo搜索优化
  • 团队建设海报网站官网seo
  • godaddy托管wordpress福州seo快速排名软件
  • 中国最大的电商平台是哪家百度seo教程视频
  • wordpress归档cssseo排名优化推广
  • 上哪个网站做forma和co关键词歌词表达的意思