kaseyhebe 2015-01-21 03:06 采纳率: 21.1%
浏览 2159
已采纳

大神请进,帮忙看下这个Collection的排序。

package com.jeffge;

import java.util.*;

public class StringSorting {
public static void main(String[] args) {
ArrayList persons = new ArrayList();
persons.add(new Person("Sam", 25));
persons.add(new Person("Sam", 35));
persons.add(new Person("Tom", 25));
persons.add(new Person("Tom", 35));
persons.add(new Person("Jeff", 25));
persons.add(new Person("Jeff", 35));
persons.add(new Person("Herry", 25));
persons.add(new Person("Herry", 35));
persons.add(new Person("Kim", 25));
persons.add(new Person("Kim", 35));
persons.add(new Person("Matthew", 25));
persons.add(new Person("Matthew", 35));
persons.add(new Person("Chris", 25));
persons.add(new Person("Chris", 35));
persons.add(new Person("Jakes", 25));
persons.add(new Person("Jakes", 35));
persons.add(new Person("Josh", 25));
persons.add(new Person("Josh", 35));
String expected = persons.toString();
println(persons);
Collections.shuffle(persons);

    Collections.sort(persons, new PersonComparator());

    String result = persons.toString();

    println("It is now   : "+result);
    println("It should be: " + expected);

    if(result.equals(expected)){
        println("It works!");
    } else {
        println("Keep trying!");
    }

}

private static void println(Object s) {
    System.out.println(s);
}


private static class Person {
    String name;
    int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public String toString() {
        return name + "-" + age ;
    }


}


private static class PersonComparator implements Comparator<Person> {
    @Override
    public int compare(Person a, Person b) {
        return 0;
    }
}

}
请问 最下面实现的那个Compare 接口 怎么写 才能执行呀。 先按照名字排序,如果名字一样,然后按照年龄排序

  • 写回答

7条回答 默认 最新

  • GalinaY 2015-01-21 05:51
    关注

    private static class PersonComparator implements Comparator {
    @Override
    public int compare(Person a, Person b) {
    if(a.name.equalsIgnoreCase(b.name)){
    //年龄是按照从小到大的排列
    if(a.age < b.age){
    return -1;
    }else if(a.age > b.age){
    return 1;
    }else{
    return 0;
    }
    }else{
    return a.name.compareTo(b.name);
    }

    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(6条)

报告相同问题?

悬赏问题

  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法
  • ¥15 可否在不同线程中调用封装数据库操作的类
  • ¥15 微带串馈天线阵列每个阵元宽度计算
  • ¥15 keil的map文件中Image component sizes各项意思
  • ¥20 求个正点原子stm32f407开发版的贪吃蛇游戏
  • ¥15 划分vlan后,链路不通了?
  • ¥20 求各位懂行的人,注册表能不能看到usb使用得具体信息,干了什么,传输了什么数据