2 oiu1010110 oiu1010110 于 2016.04.23 13:22 提问

java 集合排序问题,谢谢指导。

有一串分数我存在了rationalList集合里,然后要求对分数按倒数大小对分数进行排序
ListrationalList = new ArrayList<>();
Collections.sort(rationalList,new InverseComparator());
public class InverseComparator implements Comparator {
// 比较两个分数倒数的大小
@Override
public int compare(Rational obj1, Rational obj2) {
Rational ra1 = obj1;
Rational ra2 = obj2;
int nm1 = obj1.getNumerator();
int dm1 = obj1.getDenominator();
ra1.setDenominator(nm1);
ra1.setNumerator(dm1);

    int nm2 = obj2.getNumerator();
    int dm2 = obj2.getDenominator();
    ra2.setDenominator(nm2);
    ra2.setNumerator(dm2);  这里这样的话就改变了原来的分数,后面输出来的都是倒数,而不是原来的分数,怎么写呢要?
    //……
}
}

3个回答

oiu1010110
oiu1010110   2016.04.23 19:58
已采纳

public int compare(Rational obj1, Rational obj2) {

    int nm1 = obj1.getNumerator();
    int dm1 = obj1.getDenominator();
    Rational ra1 = null;
    try {
        ra1 = new Rational(dm1,nm1);
    } catch (IllegalRationalException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }

    int nm2 = obj2.getNumerator();
    int dm2 = obj2.getDenominator();
    Rational ra2 = null;
    try {
        ra2 = new Rational(dm2,nm2);
    } catch (IllegalRationalException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    //……这里用前面本身排序的compareTo();只是参数换成了两个比较
    }



    //已解决
CSDNXIAOD
CSDNXIAOD   2016.04.23 13:32

java集合排序问题
Java集合中的排序问题
Java集合中的排序问题
----------------------biu~biu~biu~~~在下问答机器人小D,这是我依靠自己的聪明才智给出的答案,如果不正确,你来咬我啊!

molashaonian
molashaonian   2016.04.23 15:15

继承Comparable接口,自己写排序方法
class Name implements Comparable{

public String firstName,lastName;

public Name(String firstName,String lastName){

this.firstName=firstName;

this.lastName=lastName;

}

public int compareTo(Name o) { //实现接口

int lastCmp=lastName.compareTo(o.lastName);

return (lastCmp!=0?lastCmp:firstName.compareTo(o.firstName));

}

public String toString(){ //便于输出测试

return firstName+" "+lastName;

}

}

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
Java集合排序及java集合类详解
Java集合排序及java集合类详解 Java集合排序及java集合类详解
java中集合排序
java中集合排序
java HashSet 集合排序
java HashSet 集合排序,需要通过利用TreeSet集合排序。2013-10-30。
Java集合排序及java集合类详解.pdf
Java 集合排序 及java集合类 详解.pdf
collections集合操作排序,Java8 stream集合操作
/** * */ package com.wen; import java.math.BigDecimal; /** * @author wencun * @date 2018年2月22日 上午9:49:37 * @version 1.0 * @since JDK 1.8 */ public class Staff { private String name; ...
Java对List集合的排序
由于其功能性和灵活性,ArrayList是 Java 集合框架中使用最为普遍的集合类之一。ArrayList 是一种 List 实现,它的内部用一个动态数组来存储元素,因此 ArrayList 能够在添加和移除元素的时候进行动态的扩展和缩减。 使用Collections工具类进行排序: 使用Collections排序非常简单,我们只需要把实现了Comparable接口的类传入里面调用一下C
Collections工具类详解
Collections.sort(list, comparator); comparator 是Comparator接口的实现对象 例如1.简历集合按时间排序 ComparatorResume comparator=new ComparatorResume(); Collections.sort(educationlist, comparator);   public class Co
java中Map集合的排序方法
HashMap的应用实例 Map中元素存放是无序的 HashMap注意事项: 1,HashMap底层维护一个数组,我们向HashMap中所放置的对象实际上是存储在该数组当中; 2,当向HashMap中put一对键值时,它会根据key的hashCode值计算出一个位置,该位置就是此对象准备往数组中存放的位置。 HashMap应用举例:控制台输入一句英语,简单统计各个单词出现的次数
java泛型集合 java集合 集合 java Collection
java泛型集合 java集合 集合 java Collection 排序 集合排序
java集合进行排序的两种方式
java集合的工具类Collections中提供了两种排序的方法,分别是: Collections.sort(List list)//自然排序 Collections.sort(List list,Comparator c)//定制排序 第一种称为自然排序,参与排序的对象需实现comparable接口,重写其compareTo()方法,方法体中实现对象的比较大小规则,示例如下: 实体类: