今天练习了一题: 数据流中位数 问题描述:数字是不断进入数组的,在每次添加一个新的数进入数组的同时返回当前新数组的中位数. 案例: 持续进入数组的数的列表为:[1, 2, 3, 4, 5],则返回[1, 1, 2, 2, 3] 持续进入数组的数的列表为:[4, 5, 1, 3, 2, 6, 0],则返回 [4, 4, 4, 3, 3, 3, 3] 持续进入数组的数的列表为:[2, 20, 100],则返回[2, 2, 20] 个人实现代码如下: main方法: public static voi…
[抄题]: 数字是不断进入数组的,在每次添加一个新的数进入数组的同时返回当前新数组的中位数. [思维问题]: [一句话思路]: 左边x个元素,右边要有x+1个元素,因此利用maxheap把左边的最大值揪出来,利用minheap把右边的最小值揪出来 如果maxHeap.peek() > minHeap.peek(),就不断流动,直到顺滑. [输入量]:空: 正常情况:特大:特小:程序里处理到的特殊情况:异常情况(不合法不合理的输入): [画图]: [一刷]: 接口类是Queue<Integer&…
注意multiset的一个bug: multiset带一个参数的erase函数原型有两种.一是传递一个元素值,如上面例子代码中,这时候删除的是集合中所有值等于输入值的元素,并且返回删除的元素个数:另外一种是传递一个指向某个元素的iterator,这时候删除的就是这个对应的元素,无返回值. https://www.cnblogs.com/lakeone/p/5600494.html 删除的时候一定不能删除指针,只能删除迭代器 leetcode那个题就是在这个地方出错的: Input: [3,2,3…
比较两个文本的相似度 这里采用 simHash 算法 ; 分词是 基于 http://hanlp.linrunsoft.com/ 的开源 中文分词包 来实现分词 ; 实现效果图: 直接上源码: https://pan.baidu.com/s/1hr4ymKs kbih…
00 前言 经过小编不断的努力,关于column generation求解VRPTW的代码终于新鲜出炉啦. 01 运行说明 关于这部分的代码,这里提供两个版本. 第一个版本GitHub一个叫Seminar的国外大神写的,他的子问题求解采用的是建模的方式(建模请看上一期的教程),找一条reduced cost最短的路径,运行只需要更改下面文件中算例文件的路径即可. 运行的中间结果如下: Iteration:迭代次数 SbTime:子问题求解时间(s) nPaths:Master Problem中的…
lookup(key) Return the list of values in the RDD for key key. This operation is done efficiently if the RDD has a known partitioner by only searching the partition that the key maps to. >>> l = range(1000) >>> rdd = sc.parallelize(zip(l,…
题目描述 如何得到一个数据流中的中位数?如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值.如果从数据流中读出偶数个数值,那么中位数就是所有数值排序之后中间两个数的平均值.我们使用Insert()方法读取数据流,使用GetMedian()方法获取当前读取数据的中位数. 题目分析 不同的数据结构对应着不同的解法,平时做题的时候要时刻想着该选用什么数据结构 数据结构 插入的时间复杂度 得到中位数的时间复杂度 没有排序的数组 O(1) O(n) 排序的数组 O(n) O(1)…
java中的I/O操作主要是基于数据流进行操作的,数据流表示了字符或者字节的流动序列. java.io是数据流操作的主要软件包 java.nio是对块传输进行的支持 数据流基本概念 “流是磁盘或其它外围设备中存储的数据的源点或终点.” 在电脑上的数据有三种存储方式,一种是外存(硬盘,磁盘,优盘),一种是内存,一种是缓存:对于内存和外存的理解,我们可以简单的理解为容器,即外存是一个容器,内存又是另外一个容器,数据流的作用就是将两个容器连接起来 java中io部分包括标准输入输出,文件的操作,网络上…
最近工作需要 要求把python的代码写成java版本,python中有一个np.median()求中位数的方法,java决定手写一个 先说说什么是中位数: 中位数就是中间的那个数, 如果一个集合是奇数个,那么中位数就是按大小排列后,最中间那个数, 如果一个集合是偶数个,那么中位数就是按大小排列后,最中间那2个数的平均数. 比如: 1,2,3,4,5  那中位数就是3 1,2,3,4,5,6 那中位数就是 (3+4)/2 = 3.5 知道逻辑后方法就很简单了 下面是代码 public stati…
Java Collections API和泛型 数据结构和算法 学会一门编程语言,你可以写出一些可以工作的代码用计算机来解决一些问题,然而想要优雅而高效的解决问题,就要学习数据结构和算法了.当然对数据结构和算法的理解在开发优秀的软件时是非常重要的,与其同等重要的是在我们的开发工作中应用软件工程中的一些良好准则.邹欣老师(博客,微博,豆瓣)的<现代软件工程讲义>提到三个公式: 程序 = 数据结构+算法 软件 = 程序 + 软件工程 软件企业 = 软件 + 商业模式 我们学习编写程序是要来解决实际…