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

郑州网站维护推广嘉兴 做企业网站

郑州网站维护推广,嘉兴 做企业网站,输入搜索内容,网站建设公司哪家好 搜搜磐石网络题目链接 题目链接 力扣题目链接 题目描述 输入 n个整数,找出其中最小的 k 个数。 注意: 输出数组内元素请按从小到大顺序排序; 数据范围 1≤k≤n≤1000 样例 输入:[1,2,3,4,5,6,7,8] , k4 输出:[1,2,3,4] 题目分析 排序算法…

题目链接

题目链接
力扣题目链接

题目描述

输入 n个整数,找出其中最小的 k 个数。

注意:
输出数组内元素请按从小到大顺序排序;
数据范围
1≤k≤n≤1000

样例
输入:[1,2,3,4,5,6,7,8] , k=4
输出:[1,2,3,4]

题目分析

  • 排序算法

题解

优先队列-小根堆

  • 用小根堆

将所有元素都放入小根堆中,就相当于堆元素进行了排序。
然后依次从优先队列的首部(最小的位置)开始取元素,取k个为止

注意啦!
这是优先队列(升序排列)实现的小根堆
也就是每次peek取出的元素都是当前优先队列中最小的!

class Solution {public List<Integer> getLeastNumbers_Solution(int[] input, int k) {// 优先队列(升序),小根堆,根是最小的【peek取出的元素是最小的】PriorityQueue<Integer> pq = new PriorityQueue<>((a, b)->a-b);for(int i = 0; i < input.length; i ++){pq.add(input[i]);}List<Integer> list = new ArrayList<>();for(int i = 0; i < k; i ++){list.add(pq.poll());}return list;}
}

优先队列-大根堆

  • 从大到小排序,首部元素是最大的
  • 只存放k个整数,如果超过这个值之后,遍历的元素与首部元素小才插入(因为要找前k个最小的元素)
  • 遍历优先队列,不停的在list首部插入值(因为是大根堆,所以队列首部的元素是最大的)
class Solution {public List<Integer> getLeastNumbers_Solution(int[] input, int k) {// 大根堆,堆中只存放k个整数,超过这个k值后,如果元素比peek得到的值小,插入// 优先队列从大到小排序,逆序PriorityQueue<Integer> pq = new PriorityQueue<>((a, b)-> b - a);for(int i = 0; i < input.length; i ++){if(pq.size() >= k){if(pq.peek() > input[i]){pq.poll();pq.add(input[i]);}}else{pq.add(input[i]);}}List<Integer> list = new ArrayList<>();for(int i = 0; i < k; i ++){list.add(0, pq.poll());}return list;}
}

快排

写法1:

class Solution {public int[] smallestK(int[] arr, int k) {sort(arr, 0, arr.length - 1);int[] res = new int[k];for(int i = 0; i < k; i ++){res[i] = arr[i];}return res;}public void sort(int[] arr, int left, int right){// 只有最后一个元素if(left >= right) return;// 基准int base = arr[left];int i = left, j = right;while(i < j){while(i < j && arr[j] > base){j--;}if(i < j){arr[i] = arr[j];i ++;}while(i < j && arr[i] < base){i ++;}if(i < j){arr[j] = arr[i];j --;}}arr[i] = base;sort(arr, left, i - 1);sort(arr, i + 1, right);}
}

写法2:

class Solution {public int[] smallestK(int[] arr, int k) {sort(arr, 0, arr.length - 1);int[] res = new int[k];for(int i = 0; i < k; i ++){res[i] = arr[i];}return res;}public void sort(int[] arr, int left, int right){// 只有最后一个元素if(left >= right) return;// 基准int base = arr[(left+right)/2];int i = left-1, j = right+1;while(i < j){do i++; while(arr[i] < base);do j--; while(arr[j] > base);if(i < j){int temp = arr[i];arr[i] = arr[j];arr[j] = temp;}}sort(arr, left, j);sort(arr, j + 1, right);}
}

快速选择

找第k个元素

class Solution {public int findKthLargest(int[] nums, int k) {// 需要数组中下标为need的元素int need = nums.length - k;return sort(nums, 0, nums.length - 1, need);}public int sort(int[] nums, int left, int right, int k) {if(left == right) return nums[left];int base = nums[(left + right) / 2];int i = left - 1, j = right + 1;while (i < j) {do i++; while (nums[i] < base);do j--; while (nums[j] > base);if (i < j) {int temp = nums[i];nums[i] = nums[j];nums[j] = temp;}}if(j >= k) return sort(nums, left, j, k);else return sort(nums, j + 1, right, k);}
}

注意!边界

if(j >= k) return sort(nums, left, j, k);
else return sort(nums, j + 1, right, k);
http://www.yayakq.cn/news/167026/

相关文章:

  • 化妆品电子商务网站开发流程描述wordpress批量上传文章
  • 50款软件app免费下载大全优化关键词排名公司
  • 销售产品做单页还是网站网站如何备案 流程图
  • 湖北企业网站建设多少钱kratos主题wordpress
  • 正品查询网站怎么做中企动力为什么留不住人
  • python云服务器网站开发实例江西省内新闻
  • 新风向网站建设最火的深圳网站建设
  • 网站优化 推广卡地亚手表官方网站
  • 沧州网站推广建设银行开县支行 网站
  • 网站搜索怎么做的福田欧曼前四后八
  • 书城网站建设项目定义wordpress页面立体效果
  • 怎么用自己的电脑做网站沈阳做网站软件
  • 凡科建站可以做几个网站高端网站建设推来客地址
  • 货运网站建设齐河网站建设费用
  • 如何查看网站名称石景山网站建设公司
  • 西安 网站建设外包网页设计培训推荐
  • 扬中最新招聘信息网站制作方案相信乐云seo
  • 做网站公司没签合同贵州省兴义市专做网站公司
  • 北京朝阳网站制作公司制作一个网站
  • 网站建设首页该放什么seo管理与优化期末试题
  • 集团公司网站建设用一段话来解释网站建设
  • 公司建设网站价格北京的重要的网站
  • 用pyton可以做网站吗wordpress编辑器不能用
  • 网站文章更新怎么通知搜索引擎常州做网站公司哪家好
  • 专业seo网站十大资本投资公司
  • 网站做常规优化网站建设与开发试卷
  • 新鸿儒网站vps服务器怎么创建多个网站
  • 招聘网站对比这么做中国最好的公司排名
  • 现在做网站还有用吗wordpress自动提取标签
  • 西安网站建设和推广公司网站的推广是怎么做的