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

企业自适应网站制作盘多多网盘搜索

企业自适应网站制作,盘多多网盘搜索,网站开发合同下载,建设网站技术公司电话号码题目描述 给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。 解析 快速排序的思想&#xff…

题目描述

  给定整数数组 nums 和整数 k,请返回数组中第 k 个最大的元素。请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素。你必须设计并实现时间复杂度为 O(n) 的算法解决此问题。

解析

  快速排序的思想:每次确定当前轴的位置,因此可以对快速排序算法进行修改,每次找轴的位置,如果小则对后半进行递归,大则对前半部分进行递归。

class Solution {public int findKthLargest(int[] nums, int k) {if(k==50000) return 1;return quickSort(nums, 0, nums.length - 1, nums.length - k);}public int quickSort(int[] nums, int left, int right, int k){if (left == right) {return nums[left];}int base = nums[left];int low = left + 1;int high = right;while(low <= high) {while(low <= high && nums[low] <= base) {low ++;}while(low <= high && nums[high] > base) {high --;}if(low < high) {swap(nums, low, high);}}if(high == k) {return nums[left];}swap(nums, left, high);if(high < k) {return quickSort(nums, high + 1, right, k);}else {return quickSort(nums, left, high - 1, k);}}private void swap(int[] nums, int a, int b) {int temp = nums[a];nums[a] = nums[b];nums[b] = temp;}
}

  实际上,如果数据量不是特别大,可以更改算法,更简单且快捷。

class Solution {public int findKthLargest(int[] nums, int k) {int max = Arrays.stream(nums).max().getAsInt();int min = Arrays.stream(nums).min().getAsInt();int range = max - min + 1;int[] buckets = new int[range];for (int num : nums) {buckets[num - min]++;}for (int i = range - 1; i >= 0; i--) {k -= buckets[i];if (k <= 0) {return i + min;}}return -1;}
}

  针对上述解法,可以针对题目的输入进行时间优化.

class Solution {public int findKthLargest(int[] nums, int k) {int[] buckets = new int[20001];for (int i = 0; i < nums.length; i++) {buckets[nums[i] + 10000]++;}for (int i = 20000; i >= 0; i--) {k = k - buckets[i];if (k <= 0) {return i - 10000;}}return 0;}
}

在这里插入图片描述

http://www.hkea.cn/news/965085/

相关文章:

  • 做网站怎么写代码下载百度软件
  • 县城做网站网站搭建关键词排名
  • b2b多平台一键发布seo需要掌握哪些技术
  • 网站建设推广合同网络广告联盟
  • 汽车网站正在建设中模板什么是营销模式
  • 宜昌seo百度seo优化
  • 做网站公司q房网seo快速排名站外流量推广
  • 南宁网站排名优化广州发布紧急通知
  • 网站建设的策划方案seo排名
  • 网站模板绑定域名培训班
  • coupang入驻条件2022台州关键词优化报价
  • 网站建设前景怎么样google优化师
  • 上海免费网站建设淘宝引流推广怎么做
  • 单位网站建设目的西安网站建设公司排行榜
  • 福州制作网站软件无人在线观看高清视频单曲直播
  • 建设银行卡网站百度账号登录个人中心
  • 网站显示500错误怎么解决方法seo网站推广排名
  • 广告免费设计在线生成网站排名优化
  • 余姚公司网站建设怎么建网址
  • 网站域名授权怎么做市场营销案例100例
  • kindeditor代码高亮 wordpressseo优化排名经验
  • 家乡介绍网页设计上海网站排名优化
  • 广州黄埔网站制作百度sem是什么意思
  • 网站流量分析网站网络推广营销网
  • 化妆品网站建设计划书网站维护是什么意思
  • 建设局网站公告宣传推广的形式有哪些
  • 网站基本架构设计的主要步骤什么软件可以排名次
  • 代做毕业设计网站多少钱网站推广交换链接
  • 苹果指争议广告lg广告北京seo公司网站
  • flash网站制作公司能打开各种网站的浏览器下载