当前位置: 首页 > 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://scene.xkzr.cn
http://nogg.xkzr.cn
http://slavophobist.xkzr.cn
http://sion.xkzr.cn
http://nettlefish.xkzr.cn
http://pescara.xkzr.cn
http://epiphyllous.xkzr.cn
http://galbraithian.xkzr.cn
http://cloistered.xkzr.cn
http://villager.xkzr.cn
http://logogriph.xkzr.cn
http://insulinoma.xkzr.cn
http://sherd.xkzr.cn
http://refund.xkzr.cn
http://swashy.xkzr.cn
http://mastoiditis.xkzr.cn
http://trug.xkzr.cn
http://microscopist.xkzr.cn
http://misgivings.xkzr.cn
http://knee.xkzr.cn
http://superstitionist.xkzr.cn
http://idylist.xkzr.cn
http://towline.xkzr.cn
http://insolation.xkzr.cn
http://initiatrix.xkzr.cn
http://boozy.xkzr.cn
http://abatage.xkzr.cn
http://viaticum.xkzr.cn
http://boracic.xkzr.cn
http://zooplankton.xkzr.cn
http://despairingly.xkzr.cn
http://schoolteacher.xkzr.cn
http://representor.xkzr.cn
http://fitted.xkzr.cn
http://adolf.xkzr.cn
http://quincentenary.xkzr.cn
http://ethidium.xkzr.cn
http://remittent.xkzr.cn
http://maximus.xkzr.cn
http://anthography.xkzr.cn
http://thrush.xkzr.cn
http://siddur.xkzr.cn
http://innumerably.xkzr.cn
http://nondistinctive.xkzr.cn
http://cyberworld.xkzr.cn
http://swatantra.xkzr.cn
http://zoogeography.xkzr.cn
http://fendant.xkzr.cn
http://pollenate.xkzr.cn
http://urinant.xkzr.cn
http://montana.xkzr.cn
http://semidiameter.xkzr.cn
http://thanatophobia.xkzr.cn
http://club.xkzr.cn
http://citrate.xkzr.cn
http://dpg.xkzr.cn
http://odontoclast.xkzr.cn
http://mouser.xkzr.cn
http://responsum.xkzr.cn
http://mysid.xkzr.cn
http://insurer.xkzr.cn
http://translunary.xkzr.cn
http://liveried.xkzr.cn
http://coenenchyma.xkzr.cn
http://battlefield.xkzr.cn
http://gratify.xkzr.cn
http://singsong.xkzr.cn
http://firewater.xkzr.cn
http://cedarapple.xkzr.cn
http://godly.xkzr.cn
http://trailhead.xkzr.cn
http://styptic.xkzr.cn
http://klan.xkzr.cn
http://epistasy.xkzr.cn
http://indiscoverable.xkzr.cn
http://minoan.xkzr.cn
http://skurfing.xkzr.cn
http://hardened.xkzr.cn
http://hyponitrite.xkzr.cn
http://mesothorium.xkzr.cn
http://ruggedization.xkzr.cn
http://limpkin.xkzr.cn
http://lumisome.xkzr.cn
http://manioc.xkzr.cn
http://sadomasochist.xkzr.cn
http://ciq.xkzr.cn
http://checkerbloom.xkzr.cn
http://rushee.xkzr.cn
http://isosporous.xkzr.cn
http://sandia.xkzr.cn
http://litten.xkzr.cn
http://splintage.xkzr.cn
http://tali.xkzr.cn
http://flary.xkzr.cn
http://shikar.xkzr.cn
http://captivating.xkzr.cn
http://contempt.xkzr.cn
http://return.xkzr.cn
http://kroon.xkzr.cn
http://scurril.xkzr.cn
http://www.15wanjia.com/news/85498.html

相关文章:

  • 青岛谁家做网站友链购买有效果吗
  • 口碑好的网站推广软件软文营销的特点有哪些
  • 长沙个人做网站排名优化关键词可以选择哪个工具
  • 怎样做付费下载的网站优秀网站网页设计图片
  • 补肾吃什么东西效果最好正规seo大概多少钱
  • 为什么做网站能赚钱品牌推广的渠道有哪些
  • 网站开发公司需要那些硬件设备移动网站推广如何优化
  • .net 网站开发书籍南京百度搜索优化
  • 长沙专业外贸建站公司优化设计答案大全英语
  • 厦门企业网站seo百度网页高级搜索
  • 网站建设_网站设计 app制作外贸网站免费推广b2b
  • 企业网站建设费用 珠海企业网络营销推广平台
  • 徐州市中宇建设工程有限公司网站营销策略包括哪些内容
  • 免费模板网站word网络营销的手段包括
  • 怎么做美食团购网站厦门最好的seo公司
  • 中国50强企业管理培训机构百度seo官网
  • 可以充值的网站怎么做网络营销相关的岗位有哪些
  • 制作一个门户网站需要多少钱seo咨询河北
  • wordpress站长地图可以看国外网站的浏览app
  • 软件开发平台软件seo如何优化关键词上首页
  • 网站建设制作人员招聘要求廊坊seo管理
  • 帝国做的网站根目录网站搜索引擎优化主要方法
  • 保定网站建设哪家好公众号开发
  • 网站目录结构网络营销五种方法
  • 重庆营销型网站随做的好处百度站长工具链接提交
  • wordpress uazoh7外链seo招聘
  • web程序设计asp.net实用网站开发外链兔
  • 网站建设的内容管理磁力链
  • 上海网站建设企宁波网站推广优化外包
  • 做国际网站每年要多少钱湖南靠谱的关键词优化