黑马程序员技术交流社区
标题:
求100万个数中最大的100个数
[打印本页]
作者:
blensmile
时间:
2015-10-27 23:21
标题:
求100万个数中最大的100个数
本帖最后由 blensmile 于 2015-10-27 23:31 编辑
import java.util.ArrayList;
import java.util.Comparator;
import java.util.Random;
import java.util.TreeMap;
import java.util.TreeSet;
public class MillionNumber {
/*
* 求100万个数中最大的100个数
* 分析:
* 1.采用随机数的方式产生100,0000个数
* 2.用二叉树来存储数据,向其中存100个数,
* 3.在循环里继续产生随机数,把这个数与树存储的第一个数比较,如果新数更大,删除树的第一个数,存储新数
* 4.有个bug,要优化,按照默认的比较,树里面有的数就不添加了,需要重写compare方法,避免忽略掉重复的数
* @2015.10.27
*/
public static void main(String[] args) {
// ArrayList<Integer> list = new ArrayList<>();
TreeSet<Integer> tree = new TreeSet<>( //重写步骤:导包,创建Comparator<>对象,重写compare方法,确定返回值
//@override
new Comparator<Integer>(){
public int compare(Integer a1,Integer a2){
return a1>a2? 1:-1; //大于就返回1,添加在右边,小于和等于返回-1,添加在左边
}
});
Random rand = new Random(); //创建Random对象
long startTime=System.currentTimeMillis();//计时
int i = 0;
while(i<100){
tree.add( rand.nextInt() ); //先添加100个数
i++;
}
int temp;
while(i++<10000000){ // 测试1千万个数
temp = rand.nextInt();
if(temp > tree.first()){ //temp与tree的第一个数比较
tree.pollFirst(); //删除第一个
tree.add(temp); //添加temp到树
}
}
System.out.println(tree);
System.out.println(tree.size());
System.out.println("\nTest1 runtime :"+(System.currentTimeMillis()-startTime)+"ms");
}
}
复制代码
作者:
xu不是许
时间:
2015-10-27 23:24
沙发mmmmm
作者:
kongminggg
时间:
2015-10-27 23:58
思路不错,学习了
作者:
然子
时间:
2015-10-28 00:13
niu!!!!!!!!!!!!!!!!!!!!!!!!!
作者:
liuch111
时间:
2015-10-28 00:29
厉害 ·· ·· ·
作者:
gao353263372
时间:
2015-10-28 09:07
厉害呀!
作者:
depp
时间:
2015-10-28 10:01
用集合的方法,学习了。
作者:
赵存金
时间:
2015-10-28 10:10
厉害。。。加油
作者:
WosLovesLife
时间:
2015-10-28 10:15
我以为是sort排下序然后去前一百个就行了……
作者:
momoxixi
时间:
2015-10-28 15:20
好厉害 这么牛逼
作者:
kunsongjack
时间:
2015-10-28 18:53
这么多的数,
作者:
maxwell247
时间:
2015-10-28 19:32
谢谢分享. 学习到了.
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2