码迷,mamicode.com
首页 > 其他好文 > 详细

(分治)输出前m大的数。。。

时间:2020-02-27 23:47:47      阅读:137      评论:0      收藏:0      [点我收藏+]

标签:部分   绝对值   时间   整数   大小   描述   完成   bsp   done   

描述
给定一个数组包含n个元素,统计前m大的数并且把这m个数从大到小输
出。
输入
第一行包含一个整数n,表示数组的大小。n < 100000。
第二行包含n个整数,表示数组的元素,整数之间以一个空格分开
。每个整数的绝对值不超过100000000。
第三行包含一个整数m。m < n。
输出
从大到小输出前m大的数,每个数一行。

思路:

排序后输出(nlogn)

用分治处理(n+mlogm)

关键:n时间内将前m大的都移到最右边

 

引入操作
arrangeRight(k) :把数组(或数组的一部分)前k大的
都弄到最右边
如何将前k大的都弄到最右边
1)  设key=a[0], 将key挪到适当位置,使得比key小的元素都在
key左边,比key大 的元素都在key右边(线性时间完成)
2)  选择 数组的前部或后部再进行arrangeRight操作

 

当a=k时, done
   a> k    对右边a-1个元素再进行arrangeRight (k)
   a< k    对左边b个元素再进行arrangeRight(k-a)

 

(分治)输出前m大的数。。。

标签:部分   绝对值   时间   整数   大小   描述   完成   bsp   done   

原文地址:https://www.cnblogs.com/lijiahui-123/p/12375182.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!