在一个有序数组中查询一个最大的数最优的时间复杂度是多少? O(logn) 在一个无序数组中查询一个最大的数最优的时间复杂度是多少? O(n) 在一个无序数组中查询一个最大数和一个次大数的最优时间复杂度是多少? 能否在n+logn-2次比较重完成? 根据题意出现logn,则肯定用到二分或者堆的思路,但是输入的数没有经过排序,而且题目要求的计算量也不允许排序。这样,就肯定会用到类似堆的思路,但是直接构造堆等同于排序。 堆的思想跟竞标赛类似,都是父节点>=(<=)子节点。如果父节点都是从子节点而来,这样就是竞标赛;如果不是,这样就是堆。
堆(Heap)不是一个序列式容器,在C++中也不属于STL容器是组件 堆是幕后英雄,在python中有一个模块为heapq,意思是用heap实现的 priority queue,实际上是一个小顶堆。在排序算法中有堆排序,在Topk算法中,大顶堆\小顶堆更是功不可没 本文参考python源代码,了解堆的实现与使用
给定两个具有n个元素的数组X和Y,X和Y已排好序,X+Y的中位数,共2n个元素,期望lnN级别的解决 易知,中位数两边的数都是n个,那么假设该中位数是X[mid],则其左边的数构成为:``X[0:mid-1]+Y[0:n-1-mid]``,其右边的数构成为:``X[mid:n-1]+Y[mid:n-1]``,故可知中位数X[mid]满足条件如下:
分治与递归是计算机处理问题解决问题两大法宝 整数划分涉及三个问题: 1、将一个正整数n拆成一组数连加并等于n的形式,且这组数中的最大加数不大于m 2、将正整数划分成连续的正整数之和 3、将正整数进行因子分解
最短路径算法 在日常生活中,我们如果需要常常往返A地区和B地区之间,我们最希望知道的可能是从A地区到B地区间的众多路径中,那一条路径的路途最短。最短路径问题是图论研究中的一个经典算法问题, 旨在寻找图(由结点和路径组成的)中两结点之间的最短路径。 算法具体的形式包括:
最经典的问题,往往会产生最经典的算法,比如背包与递归,比如单源最短路径与Dijkstra,比如字符串匹配与KMP 给定一个字符串S,一个模式串P,请查找P在S中的位置
本站用iframe来弹出博文,博文较长的时候会有滚动条的情况出现(chrome下做了隐藏),当滚动iframe内部的内容结束的时候,会接着滚动外层滚动条,带来一些不想要的效果 所以我们想,当iframe弹出框的时候,禁用外层滚动条 不能用overflow:hidden的方式, 因为原来的必须可以滚动, 如果暗层出来设置overflow:hidden的话会使视窗中的界面突然变宽。