Java 多关键字排序

继承 Comparable接口

一开始默认可以在类内部重写排序规则:

首先继承排序接口:Comparable<Person>

int compare(Person p1, Person p2) 返回一个基本类型的整型,

返回负数表示:p1 小于 p2,

返回0 表示: p1 和 p2相等,

返回正数表示:p1 大于 p2

所以重写排序规则的时候很灵活。如果类型是数字的话,可以直接用前一个减后一个, 
其他类型用 compareTo 函数。

如果从大到小排就 return 的时候把 p1 and p2 调换一下。
package com.ytc.alpha;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class Person implements Comparable<Person>{
    private String name;
    private Integer age;

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    @Override
    public int compareTo(Person o) {
        return this.age - o.age;
    }

    public static void main(String[] args) {
        List<Person> plist = new ArrayList<Person>();
        Person p1 = new Person("0001", 14);
        Person p4 = new Person("0004",23);
        Person p5 = new Person("0005",25);
        Person p3 = new Person("0003",25);
        Person p6 = new Person("0006",25);
        Person p7 = new Person("0007",25);
        Person p2 = new Person("0002",20);

        plist.add(p1);
        plist.add(p2);
        plist.add(p3);
        plist.add(p4);
        plist.add(p5);
        plist.add(p6);
        plist.add(p7);
        for(Person person : plist){
            System.out.println("排序前的结果:"+person.getName() + " " + person.getAge());
        }
        Collections.sort((plist));

        System.out.println();
        for(Person person : plist){
            System.out.println("排序前的结果:"+person.getName() + " " + person.getAge());
        }
    }
}

 

比较器的使用

默认是用 age 排序,但是有的时候需要用 name 来排序怎么办? 这个时候比较器 :Comparator 就排上用场了。

Comparator 的使用有两种方式:

  • Collections.sort(list,Comparator<T>);

  • list.sort(Comparator<T>);

其实主要是看 `Comparator` 接口的实现,重写里面的 `compare` 方法。代码如下:

// 方法一
Collections.sort(plist, new Comparator<Person>(){
  @Override
  public int compare(Person p1, Person p2) {
    //按照Person的年龄进行升序排列,如果年龄一样按照姓名从大到小排序
    if (p1.getAge() == p2.getAge())
      return p2.getName().compareTo(p1.getName());
    return p1.getAge().compareTo(p2.getAge());
  }
});

// 方法二
plist.sort(new Comparator<Person>() {
  // 倒序排列
  @Override
  public int compare(Person o1, Person o2) {
    return o2.age.compareTo(o1.age);
  }
});
// 方法三:
// 定义一个比较器的类,然后直接用就可以了, 可以不用在主程序中写比较的内容
// 这个类要继承比较器的接口,然后重写比较的规则
class idComparator implements Comparator<Person> {
    @Override
    public int compare(Person o1, Person o2) {
        return o2.getAge() - o1.getAge();
    }
}

 

 

 

### 回答1: 在Python,我们可以通过自定义类来实现关键字排序。 首先,我们可以在自定义类的构造函数设置需要排序关键字。假设我们需要按照学生的年龄(age)和成绩(score)两个关键字进行排序,我们可以这样定义一个Student类: ```python class Student: def __init__(self, name, age, score): self.name = name self.age = age self.score = score ``` 接下来,我们可以使用内置的`sorted()`函数来进行排序。为了实现关键字排序,我们可以使用`key`参数传入一个函数,该函数可以根据我们的需求来定义排序的规则。 例如,如果我们想要按照年龄升序、成绩降序的方式对学生列表进行排序,可以定义一个排序函数: ```python def sort_key(student): return (student.age, -student.score) ``` 接下来,我们可以使用`sorted()`函数进行排序: ```python students = [ Student("Tom", 20, 80), Student("Alice", 18, 90), Student("Bob", 20, 70) ] sorted_students = sorted(students, key=sort_key) ``` 执行后,`sorted_students`列表将按照我们定义的排序规则进行排序。 在这个例子,`sort_key`函数返回一个元组,元组的第一个元素是年龄,第二个元素是成绩的负值。这样可以保证年龄相同时,按照成绩的降序进行排序。 以上便是使用自定义类实现关键字排序的方法。通过定义排序函数,我们可以根据需要对多个关键字进行排序操作。 ### 回答2: 在Python,我们可以使用多关键字排序来对自定义类进行排序。 首先,我们需要定义一个自定义类,该类可以包含多个属性(关键字)。假设我们的自定义类为Person,具有属性name、age和salary。 我们可以通过重写类的特殊方法__lt__(小于)、__eq__(等于)和__gt__(大于)来实现对类对象的排序。这些方法分别表示对象之间的小于、等于和大于的比较操作。在这些方法,我们可以根据需要指定对象之间的比较条件。 以下是一个简单的示例代码: ```python class Person: def __init__(self, name, age, salary): self.name = name self.age = age self.salary = salary def __lt__(self, other): if self.name != other.name: return self.name < other.name if self.age != other.age: return self.age < other.age return self.salary < other.salary def __eq__(self, other): return self.name == other.name and self.age == other.age and self.salary == other.salary def __gt__(self, other): return not self.__lt__(other) and not self.__eq__(other) # 创建Person对象的列表 persons = [Person("张三", 25, 5000), Person("李四", 25, 6000), Person("王五", 30, 5000)] # 根据多个关键字进行排序 persons.sort() # 输出排序结果 for person in persons: print(person.name, person.age, person.salary) ``` 以上代码创建了一个Person类,其定义了__lt__、__eq__和__gt__方法,用于实现对象之间的比较操作。然后,我们创建了一个Person对象的列表,并使用sort方法对其进行排序。最后,我们按照指定的关键字顺序输出排序结果。 这样,就可以使用多关键字对自定义类进行排序了。 ### 回答3: 在自定义类,可以通过重写比较方法来实现关键字排序。 首先,需要定义一个包含多个属性的类,每个属性都代表了一个关键字。然后,在该类重写比较方法,使其按照指定的排序顺序进行比较。 例如,假设我们要定义一个Person类,包含姓名(name)、年龄(age)和身高(height)三个属性。我们可以按照姓名升序、年龄降序、身高降序的顺序来排序。 首先,我们定义Person类: ```java public class Person { private String name; private int age; private double height; // 构造方法、getter和setter方法省略 // 重写比较方法 public int compareTo(Person other) { // 按照姓名升序排序 int result = this.name.compareTo(other.name); if (result != 0) { return result; } // 按照年龄降序排序 result = other.age - this.age; if (result != 0) { return result; } // 按照身高降序排序 return (int) (other.height - this.height); } } ``` 接着,我们可以使用该自定义类进行排序。例如,创建一个Person对象的列表,然后使用Collections.sort()方法进行排序: ```java List<Person> personList = new ArrayList<>(); personList.add(new Person("Tom", 25, 180)); personList.add(new Person("Jerry", 30, 170)); personList.add(new Person("Alice", 20, 160)); Collections.sort(personList); for (Person person : personList) { System.out.println(person.getName()); } ``` 以上代码会按照姓名升序、年龄降序、身高降序的顺序输出人员的姓名: ``` Alice Jerry Tom ``` 这样,我们就通过重写比较方法,在自定义类实现了多关键字排序
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值