黑马程序员技术交流社区

标题: 求100万个数中最大的100个数 [打印本页]

作者: blensmile    时间: 2015-10-27 23:21
标题: 求100万个数中最大的100个数
本帖最后由 blensmile 于 2015-10-27 23:31 编辑
  1. import java.util.ArrayList;
  2. import java.util.Comparator;
  3. import java.util.Random;
  4. import java.util.TreeMap;
  5. import java.util.TreeSet;

  6. public class MillionNumber {
  7.         
  8.         /*
  9.          * 求100万个数中最大的100个数
  10.          *  分析:
  11.          *   1.采用随机数的方式产生100,0000个数
  12.          *   2.用二叉树来存储数据,向其中存100个数,
  13.          *   3.在循环里继续产生随机数,把这个数与树存储的第一个数比较,如果新数更大,删除树的第一个数,存储新数
  14.          *   4.有个bug,要优化,按照默认的比较,树里面有的数就不添加了,需要重写compare方法,避免忽略掉重复的数
  15.          * @2015.10.27
  16.          */
  17.         public static void main(String[] args) {
  18. //                ArrayList<Integer> list = new ArrayList<>();
  19.                 TreeSet<Integer> tree = new TreeSet<>(        //重写步骤:导包,创建Comparator<>对象,重写compare方法,确定返回值
  20.                                 //@override
  21.                                 new Comparator<Integer>(){
  22.                                         public int compare(Integer a1,Integer a2){
  23.                                                 return a1>a2? 1:-1;                //大于就返回1,添加在右边,小于和等于返回-1,添加在左边
  24.                                         }
  25.                                 });
  26.                
  27.                 Random rand = new Random();        //创建Random对象
  28.                 long startTime=System.currentTimeMillis();//计时
  29.                 int i = 0;
  30.                 while(i<100){
  31.                         tree.add( rand.nextInt() );        //先添加100个数
  32.                         i++;
  33.                 }
  34.                 int temp;
  35.                 while(i++<10000000){    // 测试1千万个数
  36.                         temp = rand.nextInt();
  37.                         if(temp > tree.first()){        //temp与tree的第一个数比较
  38.                                 tree.pollFirst();           //删除第一个
  39.                                 tree.add(temp);          //添加temp到树
  40.                         }        
  41.                 }
  42.                 System.out.println(tree);
  43.                 System.out.println(tree.size());
  44.                 System.out.println("\nTest1 runtime :"+(System.currentTimeMillis()-startTime)+"ms");
  45.         }
  46. }
复制代码



作者: 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