Java重修笔记 第三十五天 定制排序

  • 实现Comparator接口的定制排序
public class Arrays02 {
    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);
        // 按照price来排序
        Arrays.sort(books, new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                // 判断转换
                Book k1 = (Book) o1;
                Book k2 = (Book) o2;
                double ret = k1.price - k2.price;
                if (ret > 0) {
                    return -1;
                } else {
                    return 1;
                }
            }
        });
        // 按照书名来排序
        Arrays.sort(books, new Comparator() {
            @Override
            public int compare(Object o1, Object o2) {
                // 判断转换
                Book k1 = (Book) o1;
                Book k2 = (Book) o2;
                return k1.name.compareTo(k2.name);
            }
        });

        for (Book book : books) {
            System.out.println(book);
        }
    }
}

class Book {
    public String name;
    public double price;

    public Book(String name, double price) {
        this.name = name;
        this.price = price;
    }

    @Override
    public String toString() {
        return "Book{" +
                "name='" + name + '\'' +
                ", price=" + price +
                '}';
    }
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,针对您的问题,我可以给您提供一些思路和参考。 首先,创建视图需要重修的名单,需要根据具体的数据表和业务需求进行设计,以下是一种可能的设计思路: 1. 首先,需要有一个数据表或者视图,记录所有需要重修的学生信息,包括学生姓名、学号、课程名称、课程成绩、是否需要重修等信息。 2. 基于这个数据表,可以使用 SQL 语句创建一个视图,统计所有需要重修的学生信息,例如: ```sql CREATE VIEW view_re_exam AS SELECT student_name, student_id, course_name, course_score FROM student_score WHERE re_exam = 'Y'; ``` 这个视图会返回所有需要重修的学生信息,包括学生姓名、学号、课程名称和课程成绩。 3. 根据具体的业务需求,可以在这个视图上进一步进行统计和分析,例如: - 统计每个学生需要重修的科目数目,并按照从多到少的顺序排序: ```sql SELECT student_name, COUNT(*) AS re_exam_count FROM view_re_exam GROUP BY student_name ORDER BY re_exam_count DESC; ``` - 统计每个科目需要重修的学生数目,并按照从多到少的顺序排序: ```sql SELECT course_name, COUNT(*) AS re_exam_count FROM view_re_exam GROUP BY course_name ORDER BY re_exam_count DESC; ``` - 统计每个年级需要重修的学生数目,并按照从多到少的顺序排序: ```sql SELECT SUBSTR(student_id, 1, 2) AS grade, COUNT(*) AS re_exam_count FROM view_re_exam GROUP BY grade ORDER BY re_exam_count DESC; ``` 以上是一些基本的设计思路和 SQL 示例,具体实现需要根据您的具体业务需求和数据结构进行调整和优化。希望能对您有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值