定制排序小案例

 案例:自定义 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;
                }
            }
        }
    }

你可能感兴趣的:(韩顺平java习题,java,算法,数据结构)