繁体   English   中英

带Collections.sort的程序

[英]Programs with Collections.sort

我有Collections.sort的问题我无法解决。

我使用自定义比较器来比较基于哈希表的整数:

public class HashtableComparator<T> implements Comparator<T> {

public HashtableComparator(Map<T,Double> mapScore)
{
    this.mapScore=mapScore;
}
@Override
public int compare(T o1, T o2) {
    // TODO Auto-generated method stub
    double d1=mapScore.get(o1);
    double d2=mapScore.get(o2);

    if (d1<d2)
        return -1;
    else if (d2>d1)
        return 1;
    return 0;
}



public double getScore(T t)
{
    return mapScore.get(t);
}



private Map<T,Double> mapScore;
}

现在我按以下方式排序数字:

public static void main(String[] args)
{
  HashMap<Integer,Double> map=new HashMap<Integer,Double>();

  ArrayList<Integer> li=new ArrayList<Integer>();
  Random rn=new Random();
  for (int i=0;i<200;i++)
  {
    li.add(i);
    double r=rn.nextDouble();
    map.put(i, r);
  }
  ArrayList<Integer> li2=new ArrayList<Integer>();
  HashtableComparator<Integer> htComparator=
    new HashtableComparator<Integer>(map);

  Collections.sort(li,htComparator);
  for (Integer i1: li)
  {
    System.out.println("i: "+i1+": "+map.get(i1));
 }
 }

输出如下所示:

...我:154:0.9367974470241198

我:167:0.9426082679825352

我:158:0.9530518486042212

i:172:0.9700636428116204

i:174:0.9979504046750738

i:184:0.011633259785655103

i:187:0.03498090300936352

i:197:0.07038500463581565

我:181:0.07821108293051438

i:178:0.12297017501683705

...

完全没有森林。

有人能给我一个暗示那里出了什么问题吗? 谢谢

====

蒂姆

不要编写自己的比较逻辑,请尝试以下方法:

    @Override
    public int compare(T o1, T o2) {
       Double d1 = mapScore.get(o1);
       Double d2 = mapScore.get(o2);
       return d1.compareTo(d2);
   }

因为Double包装类实现了Comparable接口。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM