东城网站建设,建筑工程网人才网,校园o2o平台有哪些,怎样做旅游网站案例#xff1a;自定义 Book 类#xff0c;里面包含 name 和 price#xff0c;按 price 排序(从大到小)。
要求使用两种方式排序 , 有一个 Book[] books 4 本书对象.
使用前面学习过的传递 实现 Comparator 接口匿名内部类#xff0c;也称为定制排序。
可以按照 price … 案例自定义 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 ComparatorBook() {
// 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(priceValue0){
// return 1;
// }else if(priceValue0){
// return -1;
// }else {
// return 0;
// }
// }
// });//这里是对Book数组排序因此 o1 和 o2 就是Book对象Arrays.sort(books, new ComparatorBook() {Overridepublic 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(nameValue0){
// return 1;
// }else if(nameValue0) {
// 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;}Overridepublic 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;}}}}