面试题:m个长度为n的ordered array,求top k 个 数字
package com.sinaWeibo.interview; import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet; /**
* @Author: weblee
* @Email: likaiweb@163.com
* @Blog: http://www.cnblogs.com/lkzf/
* @Time: 2014年10月25日下午5:22:58
*
************* function description *************** m个长度为n的ordered array,求top
* k 个 数字 *
****************************************************
*/ public class Top1000From2000Arrays {
/*
* 从m个数组中各取一个数,并记录每个数的来源数组,建立一个含k个元素的大根堆。
* 此时堆顶就是最大的数,取出堆顶元素,并从堆顶元素的来源数组中取下一个数加入堆,再取最大值,一直这样进行k次即可。
* 时间复杂度:k*log2(20)
*/
public static int[] maxK(final int k, int[][] arrays) {
int count = 0;
Node max = null;
int[] result = new int[k]; TreeSet<Node> set = new TreeSet<Node>(new NodeComparator()); set.add(new Node(arrays[0][0], 0, 0)); for (int i = 0; i < arrays.length; i++) {
if (set.first().value < arrays[i][arrays[i].length - 1]) {
set.add(new Node(arrays[i][arrays[i].length - 1], i,
arrays[i].length - 1)); if (set.size() > k) { max = set.first();
result[count++] = max.value;
set.remove(set.first());
set.add(new Node(arrays[max.originX][max.originY - 1], max.originX,
max.originY - 1)); // testing
Iterator<Node> iter = set.iterator();
while (iter.hasNext()) {
System.out.print(iter.next().value + "\t");
}
System.out.println();
// testing
}
}
} while (true) {
max = set.first();
result[count++] = max.value; if (count == k) {
break;
} set.remove(set.first());
set.add(new Node(arrays[max.originX][max.originY - 1], max.originX,
max.originY - 1)); // testing
Iterator<Node> iter = set.iterator();
while (iter.hasNext()) {
System.out.print(iter.next().value + "\t");
}
System.out.println();
// testing
} return result;
} public static void main(String[] args) {
int[][] arrays = { { 4, 5, 6, 12 }, { 1, 2, 3, 45 }, { 3, 4, 5, 89 },
{ 101, 102, 103, 189 },{ 11, 12, 13, 289 } }; int[] result = maxK(4, arrays); for (int num : result) {
System.out.print(num + "\t");
}
} } class Node {
int value;
int originX;
int originY; public Node(int value, int originX, int originY) {
this.value = value;
this.originX = originX;
this.originY = originY;
}
} class NodeComparator implements Comparator<Node> { @Override
public int compare(Node o1, Node o2) {
// TODO Auto-generated method stub
return -(o1.value - o2.value);
} }
面试题:m个长度为n的ordered array,求top k 个 数字的更多相关文章
- 面试题:求第K大元素(topK)?
一.引言二.普通算法算法A:算法B:三.较好算法算法C:算法D:四.总结 一.引言 这就是类似求Top(K)问题,什么意思呢?怎么在无序数组中找到第几(K)大元素?我们这里不考虑海量数据,能装入内 ...
- poj3261 后缀数组求重复k次可重叠的子串的最长长度
Milk Patterns Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 13669 Accepted: 6041 Ca ...
- (笔试题)删除K位数字
题目: 现有一个 n 位数,你需要删除其中的 k 位,请问如何删除才能使得剩下的数最大? 比如当数为 2319274, k=1 时,删去 2 变成 319274 后是可能的最大值. 思路: 1.贪心算 ...
- 求小于等于k长度的最大区间和
题意 给出一个序列,求长度小于等于k的最大区间和并输出起点和终点 1<=n<=100000 1<=k<=n 题解:先算出前缀和,利用单调队列的性质,在单调队列中存储sum[ ...
- 解决js array的key不为数字时获取长度的问题
最近写js时碰到了当数组key不为数字时,获取数组的长度为0 的情况. 1.问题场景 var arr = new Array(); arr[‘s1‘] = 1001; console.log(arr. ...
- 剑指Offer面试题29(java版):数组中出现次数超过一半的数字
题目:数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 比如输入一个长度为9的数组{1,2,3,2.2,2.5,4,2}.因为数字2在数组中出现5次,超过数组长度的一半,因此输出2. 解 ...
- Day_11【集合】扩展案例4_删除长度大于5的字符串,删除元素包含0-9数字的字符串
分析以下需求,并用代码实现 1.定义ArrayList集合,存入多个字符串 如:"ab1" "123ad" "bca" "dadf ...
- [程序员代码面试指南]第9章-在两个长度相等的排序数组中找到第k小的数(二分)
题目 给定两个有序数组arr1和arr2,再给定一个整数k,返回所有的数中第k小的数. 题解 利用题目"在两个长度相等的排序数组中找到第上中位数"的函数 分类讨论 k < 1 ...
- 数轴上从左到右有n个点a[0],a[1]…,a[n-1],给定一根长度为L的绳子,求绳子最多能覆盖其中的几个点。要求算法复杂度为o(n)。
#include <iostream> using namespace std; int maxCover(int* a, int n, int l) { ; ; ; while(end ...
随机推荐
- 【转】使用VisualSVN Server搭建SVN服务器
http://blog.csdn.net/han_yankun2009/article/details/7856992 使用 VisualSVN Server来实现主要的 SVN功能则要比使用原始的 ...
- ubuntu14.04如何卸载qq
ubuntu安装了wine qq怎么去卸载呢?现在wine qq 比较好用的有ubuntukylin官网与deepin linux官网使用的deepin版本wine qq 2012国际版,还有Long ...
- Hyper-V性能-CPU分配
为新部署的微软Hyper-V环境中的主机和网络挑选合适的硬件并非易事,更不用说在生产环境中衡量和监控性能这项任务了.在这里,我和大家谈谈服务器的核心CPU与Hyper-V的结合是如何相得益彰的. 我接 ...
- HDInsight-Hadoop实战(一)站点日志分析
HDInsight-Hadoop实战(一)站点日志分析 简单介绍 在此演示样例中.你将使用分析站点日志文件的 HDInsight 查询来深入了解客户使用站点的方式.借助此分析.你可查看外部站点一天内对 ...
- android113 自定义进度条
MainActivity: package com.itheima.monitor; import android.os.Bundle; import android.app.Activity; im ...
- 通过ftp模拟网盘
package com.xiaomo.ftp.down_upload; import java.io.IOException; import java.util.ArrayList; import j ...
- svn各种问题总结
1.out of date 就是说别人已经更新到服务器了,而我修改的还不是服务器最新的. 直接Replace with 资源库的最新内容
- iOS 网络编程:XML解析
1 XML文档结构 1.1 简介 XML 指可扩展标记语言(eXtensible Markup Language).XML 被设计用来传输和存储数据.其非常像HTML的标记语言,但与之不同的是,XML ...
- JavaScript无限极菜单
<!DOCTYPE html> <html> <head> <title> New Document </title> <meta c ...
- modelsim脚本文件的编写
第一章 ModelSim介 绍 本指南是为 ModelSim5.5f版本编写的,该版本运行于UNIX和Microsoft Windows 95/98/Me/NT/2000的操作系统环境中.本指南覆盖了 ...