首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

寻找最大的K个数

给你n个数,让你找出其中最大的K个数。 解法1: 很多人上来就对其进行排序,选用不同的排序方法有不同的时间复杂度,这里我们假设使用了最快的快排,时间复杂度为O(n*logn)。...通过排序我摘出前K大的数。 但也许快排不是最优的,我们只找最大的K个数,何必要对所有的数进行排序,我们只需要进行局部排序即可,时间复杂度大概是O(N*K)。...在这里,我们只要在递归过程中选包含最大的K个数的部分进行完整的快排,而对于其他的部分只进行快排的一部分。 关于使用快排求第K大数的方法参见其他博文。...在这个基础上,只需要做小小的改进就可以完成寻找最大K个数的功能了,时间复杂度O(N)。...结果遍历所有元素后,我们都得到保存最大K个数的堆,也就到达了我们的目的。

78620
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    求一个数组的最大k个数(java)

    问题描述:求一个数组的最大k个数,如,{1,5,8,9,11,2,3}的最大三个数应该是,8,9,11 问题分析:     1.解法一:最直观的做法是将数组从大到小排序,然后选出其中最大的K个数,但是这样的解法...2.解法二:不对前K个数进行排序,回忆快排的算法中,那个partition函数,就是随机选择数组中的一个数,把比这个数大的数,放在数组的前面,把比这个数小的数放在数组的 后面,这时想如果找出的随机数,最终位置就是...K,那么最大的K个数就找出来了,沿着这个思路思考问题,但是这个函数,最后的索引位置并不一定是K,可能比K大也可能比K小,我们把找出的数组分成两部分sa,sb,sa是大的部分,sb是小的部分,如果sa的长度等于...K中元素的一部分,再从sb中找到,k-m个最大的元素,组合起来就是最终的结果,那么这时把问题简化成从sb中找k-m个最大的元素,所以总体来说这是一个递归的过程,虽然复杂大也是O(n*logn)但是,每一次数据量都会减少所以会更加的快...3.解法三:是利用堆排序,建立一个K阶最大堆,然后数据一个个插入队当中,那么插入队的时间复杂度是O(logK),适合数据量比较大的时候,用堆的效果更加好。

    86620

    三个数的最大乘积

    1 问题 给定一个正数整型数组nums(不考虑有负数的情况),在数组中找出由三个数组装成的最大乘积值,并输出这个乘积。...示例1: 输入:nums=[1,2,3] 输出:6 示例2: 输入:nums=[1,2,3,4] 输出:24 2 方法 在这个数组中,先找出原数组中最大的一个数,放入一个新列表,再将原数组中的该最大数字删去...,下次就可以找到第二个,第三个最大数字,然后将新列表里的三个数相乘,就得到了我们要的最大的三个数组装成的最大乘积。...list.append(max(nums)) nums.remove(max(nums)) cj=list[0]*list[1]*list[2] print(cj) 4 结语 针对解决数组中三个数的最大乘积问题...,提出用依次找出三个最大数字,然后相乘的方法,通过实践,证明该方法是有效的,本文的方法还存在不足的是,对于新的这个列表,在计算乘积时是利用索引依次相乘,如果该序列是字典,就没办法利用索引得到结果,未来相信可以利用更简便的方法来继续研究

    27520

    shell统计当前文件夹下的文件个数、目录个数

    shell统计当前文件夹下的文件个数、目录个数 ls -l |grep "^-"|wc -l //统计当前文件夹下文件的个数 ls -l |grep "^d"|wc -l //统计当前文件夹下目录的个数...ls -lR|grep "^-"|wc -l //统计当前文件夹下文件的个数,包括子文件夹里的 ls -lR|grep "^d"|wc -l //统计文件夹下目录的个数,包括子文件夹里的 命令拆解...grep "^-" //这里将长列表输出信息过滤一部分,只保留一般文件,如果只保留目录就是 `^d` wc -l //统计输出信息的行数,因为已经过滤得只剩一般文件了,所以统计结果就是一般文件信息的行数...,又由于一行信息对应一个文件,所以也就是文件的个数 扩展:shell脚本 //判断目录下文件数与指定文件数量是否相等的shell脚本(fileNum.sh) #!.../fileNum.sh 5 //判断当前目录下的文件数量是否为5

    13.5K10

    PostgreSQL表用户列最大个数

    PostgreSQL表用户列最大个数 有些业务可能有这么个需求:需要增加用户列,即通过ALTER TABLE ... ADD...来添加用户列。那么PG/GP中是否会有列个数的限制呢?...test=# alter table t1 add column co1601 int; psql: ERROR: table can have at most 1600 columns 会报错提示,表最大有...1600 从上图可以看到限制的值来自pg_class系统表的relnatts字段。...6)如果,我们在ATExecDropColumn的地方将pg_class系统表进行更新,将该限制规避掉,是否可行? 需要知道,drop一列后,存于磁盘上表内的记录仍旧是完整列,也就是包含删除的列。...如果修改这个限制的化,不是那么简单在drop列后更新pg_class系统表的relnatts字段值就可以的,需要仔细梳理代码,对其他流程受影响的地方都进行改造。

    32120

    linux查看文件夹下的文件个数

    linux查看文件夹下的文件个数(当前目录的文件数)//包含子目录 ls -l |grep "^-"|wc -l //验证了redhat好用 或 find ..../company -type f | wc -l 查看某文件夹下文件的个数,包括子文件夹里的。 ls -lR|grep "^-"|wc -l 查看某文件夹下文件夹的个数,包括子文件夹里的。...ls -lR|grep "^d"|wc -l 说明: ls -l 长列表输出该目录下文件信息(注意这里的文件,不同于一般的文件,可能是目录、链接、设备文件等) grep "^-" 这里将长列表输出信息过滤一部分...,只保留一般文件,如果只保留目录就是 ^d wc -l 统计输出信息的行数,因为已经过滤得只剩一般文件了,所以统计结果就是一般文件信息的行数,又由于 一行信息对应一个文件,所以也就是文件的个数。...Linux查看文件夹大小 du -sh 查看当前文件夹大小 du -sh * | sort -n 统计当前文件夹(目录)大小,并按文件大小排序 du -sk filename 查看指定文件大小 来源:https

    11K50

    【递归】递归求n个数中的最大值

    作者:每天都要记得刷题(●’◡’●) 时间:2022/04/04 本篇感悟:举一反三,由求 n的阶乘联想到递归求n个数中的最大值,对递归有了更深的了解。...文章目录 ⭐题目(代码在文末) ⭐递归思想 ⭐求前n个斐波那契数 ⭐具体代码(答案) ⭐题目(代码在文末) 使用递归求 55 ,22, 155, 77, 99这5个数中的最大值 ⭐递归思想 Q...往里套用就是: 关键:重复把求最大值这个过程重复再重复,知道找到递归出口 1.当数组只有一个元素的时候,这个数就是最大值 2.但是当n>1时,从数组下标大的一端开始自身调用**,将最后一个数和n-...1个数中的最大值进行比较(假设我们已知)** 3.然后就是求n-1个数中的最大值,也就是重复了以上的步骤 4.知道我们到了递归出口,再归回去就可以了。...a[n - 1] : find_max(a, n - 1); } int main() { //递归求n个数中的最大值 int a[5] = { 55,22,155,77,99 }; int

    1.3K20

    Linux 统计文件个数

    统计 统计当前文件夹下文件的个数,包括子文件夹里的 ls -lR|grep "^-"|wc -l [zhou@localhost logs]$ ls -lR|grep "^-"|wc -l 73 统计文件夹下目录的个数...,包括子文件夹里的 ls -lR|grep "^d"|wc -l 统计当前文件夹下文件的个数 ls -l |grep "^-"|wc -l 统计当前文件夹下目录的个数 ls -l |grep "^d"|...wc -l 备注: 统计输出信息的行数 wc -l 将长列表输出信息过滤一部分,只保留一般文件,如果只保留目录就是 ^d grep "^-" 2.查找 查找文件大小大于50M的文件 find / -size...终端的打印结果输出到文本文件中 方法1:利用符号 > 和 >> 两者的区别在于 符号 ">" 代表重写要输出的文件 [zhou@localhost logs]$ pwd > /home/zhou/path.txt...[zhou@localhost logs]$ cat /home/zhou/path.txt /mydata/tomcat9/logs ">>"代表要追加要输出的文件,不改变原文件的内容 假设文件test1

    3.1K20

    操作系统 文件管理 文件的结构

    文件的逻辑结构 设计文件逻辑结构的原则 易于操作。 查找快捷。 修改方便。 空间紧凑。 文件的逻辑结构 文件的逻辑结构就是用户所看到的文件的组织形式。...文件划分为三类逻辑结构:无结构的字符流式文件、定长记录文件和不定长记录文件构成的记录树。 定长记录文件和不定长文件可以统称为记录式文件。...流式文件 流式文件是有序字符的集合,其长度为该文件所包含的字符个数,所以又称为字符流文件。 源程序、目标代码等文件属于流式文件。UNIX内系统采用流式文件结构。...缺点:文件不能动态增长。 链接结构 链接结构原理 为每个文件构造所使用的磁盘块的链表。使用这种链接结构的文件,将逻辑上连续的文件分散存放在若干个不连续的物理块中。...文件的存储方式 在用户面前,文件的呈现方式是文件的物理结构,在存储介质面前,文件呈现的是文件的物理结构,这与文件所使用的存储介质的特性有关。

    1.5K20
    领券