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

免费大空间网站ps网页设计培训

免费大空间网站,ps网页设计培训,天津工程建设信息网官网,公司注册资金可以取出来吗题目链接 题目链接 力扣题目链接 题目描述 输入 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/575481/

相关文章:

  • 网站备案最快要几天网站不关站备案
  • 企业微信网站开发功能型网站有哪些
  • dedecms5.7装饰网站模板h5网站建设 北京
  • 注册一个免费的网站吗中交通力建设股份有限公司网站
  • 关于官方网站建设情况的汇报网页设计理念和设计构思
  • 印尼建设银行网站理财网站建设方案书
  • 网站上怎样做轮播图检察机关门户网站建设
  • html网站简易模板下载app免费下载安装下载
  • 南漳网站制作中企动力官做网站怎么样
  • 网站建设中的技术问题男女做污污的网站
  • 成都美食网站设计论文天津建站平台
  • wap网站开发教程怎么自己制作一个网站
  • 太原网站优化技术制作付款网站
  • 大连市建设学校网站旅游网站网页设计
  • 南宁网站制作计划微信公众号推广赚钱
  • 无锡网站制作企业东莞市企业网站建设平台
  • 微信端怎么建设网站如何做跨境电商怎么做
  • 营销型网站建设评价自做网站图片版权
  • 做淘客网站要备案网站开发的ui设计
  • 聊城建设银行网站杭州外贸网站建设公司申跃
  • 做外贸网站好还是内贸网站好做网站的费用
  • 电子商务网站建设过程列出网站目录
  • 大学网站建设通常做网站要多久
  • 北京网站开发怎么样wordpress数据表优化
  • 网站上动画视频怎么做动漫视频网站开发
  • 建了网站却搜不出来c2c网站建设价格
  • 网站建设教程百度网盘广州公司注册流程详解
  • 网站建设素材网怎么做网站站内优化
  • 网站建设需求分析的实施福田蒙派克质量怎么样
  • 微商怎么做_和淘宝网站一样吗?工商局网站做年报