A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© blensmile 中级黑马   /  2015-10-27 23:21  /  3372 人查看  /  11 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

本帖最后由 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. }
复制代码


11 个回复

正序浏览
谢谢分享. 学习到了.
回复 使用道具 举报
这么多的数,
回复 使用道具 举报
好厉害 这么牛逼
回复 使用道具 举报
我以为是sort排下序然后去前一百个就行了……
回复 使用道具 举报
赵存金 来自手机 中级黑马 2015-10-28 10:10:25
8#
厉害。。。加油
回复 使用道具 举报
depp 中级黑马 2015-10-28 10:01:20
7#
用集合的方法,学习了。
回复 使用道具 举报
厉害呀!
回复 使用道具 举报
厉害 ·· ·· ·
回复 使用道具 举报
niu!!!!!!!!!!!!!!!!!!!!!!!!!
回复 使用道具 举报
kongminggg 来自手机 中级黑马 2015-10-27 23:58:40
藤椅
思路不错,学习了
回复 使用道具 举报
沙发mmmmm
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马