案例:自定义 Book 类,里面包含 name 和 price,按 price 排序(从大到小)。
要求使用两种方式排序 , 有一个 Book[] books = 4 本书对象.
使用前面学习过的传递 实现 Comparator 接口匿名内部类,也称为定制排序。
可以按照 price (1)从大到小 (2)从小到大 (3) 按照书名长度从大到小
- public class ArraysExercise {
- public static void main(String[] args) {
- Book[] books = new Book[4];
- books[0] = new Book("红楼梦", 100);
- books[1] = new Book("金瓶梅新版", 90);
- books[2] = new Book("青年文摘", 5);
- books[3] = new Book("百战Java合集", 300);
-
- // Arrays.sort(books, new Comparator
() { - // @Override
- // public int compare(Book o1, Book o2) {
- // Book book1 = (Book) o1;
- // Book book2 = (Book) o2;
- // double priceValue = book1.getPrice()-book2.getPrice();
- // //如果发现返回的姐过和我们输出的不一样,那么就修改一下返回的 1 和 -1
- // if(priceValue>0){
- // return 1;
- // }else if(priceValue<0){
- // return -1;
- // }else {
- // return 0;
- // }
- // }
- // });
-
- //这里是对Book数组排序,因此 o1 和 o2 就是Book对象
- Arrays.sort(books, new Comparator
() { - @Override
- public int compare(Book o1, Book o2) {
- Book book1 = (Book)o1;
- Book book2 = (Book)o2;
- return book1.getName().length()-book2.getName().length();
- // double nameValue = book1.getName().length()-book2.getName().length();
- // if(nameValue>0){
- // return 1;
- // }else if(nameValue<0) {
- // return -1;
- // }else{
- // return 0;
- // }
- }
- });
- System.out.println(Arrays.toString(books));
- }
- }
- class Book {
- private String name = "";
-
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public double getPrice() {
- return price;
- }
- public void setPrice(double price) {
- this.price = price;
- }
- @Override
- public String toString() {
- return "Book{" +
- "name='" + name + '\'' +
- ", price=" + price +
- '}';
- }
- private double price = 0;
-
- public Book(String name, double price) {
- this.name = name;
- this.price = price;
- }
- }
以下是自己写的冒泡排序:(与该题设无关)
- public static void Bubble(int arr[], Comparator c) {
- int temp = 0;
- for (int i = 0; i < arr.length - 1; i++) {
- for (int j = 0; j < arr.length - i - 1; j++) {
- if (c.compare(arr[j], arr[j + 1]) > 0) {
- temp = arr[j];
- arr[j] = arr[j + 1];
- arr[j + 1] = temp;
- }
- }
- }
- }