栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

寻找一数组中前K个最大的数

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

寻找一数组中前K个最大的数

考察点:数组

 

public int findKthLargest(int[] nums, int k) {    if (k < 1 || nums == null) {        return 0;    }      return getKth(nums.length - k +1, nums, 0,nums.length - 1);}  public int getKth(int k, int[] nums, int start, int end) {      int pivot = nums[end];      int left = start;    int right = end;      while (true) {          while (nums[left] < pivot && left < right) { left++;        }          while (nums[right] >= pivot && right > left) { right--;        }          if(left == right) { break;        }          swap(nums,left, right);    }      swap(nums, left, end);      if (k == left + 1) {        return pivot;    } else if (k < left + 1) {        return getKth(k, nums, start, left - 1);    } else {        return getKth(k, nums, left + 1, end);    }}  public void swap(int[] nums, int n1, int n2) {    int tmp = nums[n1];    nums[n1] = nums[n2];    nums[n2] = tmp;}

 

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/363767.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号