Skip to content

  • 体验新版
    • 正在加载...
  • 登录
  • KnowledgePlanet
  • docdoc
  • Issue
  • #18

doc
doc
  • 项目概览

KnowledgePlanet / doc

通知 1303
Star 822
Fork 117
  • 代码
    • 文件
    • 提交
    • 分支
    • Tags
    • 贡献者
    • 分支图
    • Diff
  • Issue 42
    • 列表
    • 看板
    • 标记
    • 里程碑
  • 合并请求 0
  • DevOps
    • 流水线
    • 流水线任务
    • 计划
  • Wiki 2
    • Wiki
  • 分析
    • 仓库
    • DevOps
  • 项目成员
  • Pages
doc
doc
  • 项目概览
    • 项目概览
    • 详情
    • 发布
  • 仓库
    • 仓库
    • 文件
    • 提交
    • 分支
    • 标签
    • 贡献者
    • 分支图
    • 比较
  • Issue 42
    • Issue 42
    • 列表
    • 看板
    • 标记
    • 里程碑
  • 合并请求 0
    • 合并请求 0
  • Pages
  • DevOps
    • DevOps
    • 流水线
    • 流水线任务
    • 计划
  • 分析
    • 分析
    • 仓库分析
    • DevOps
  • Wiki 2
    • Wiki
  • 成员
    • 成员
  • 收起侧边栏
  • 动态
  • 分支图
  • 创建新Issue
  • 流水线任务
  • 提交
  • Issue看板
已关闭
开放中
Opened 6月 30, 2023 by 小傅哥@Yao__Shun__Yu⛹Owner

java数组里面有一堆的学生,分数。现在把这些集合按照分数的高低,排完序之后,按照分数高低返回给前端。请问该如何实现?

可以使用Java中的Arrays.sort()方法来对学生分数进行排序。具体实现步骤如下:

  1. 定义一个学生类,包含姓名和分数两个属性。
public class Student {
    private String name;
    private int score;
    
    public Student(String name, int score) {
        this.name = name;
        this.score = score;
    }
    
    // getter and setter methods
}
  1. 创建一个学生数组,并初始化学生信息。
Student[] students = new Student[]{
        new Student("张三", 90),
        new Student("李四", 80),
        new Student("王五", 85),
        new Student("赵六", 95)
};
  1. 使用Arrays.sort()方法对学生数组进行排序。
Arrays.sort(students, (s1, s2) -> s2.getScore() - s1.getScore());
  1. 将排序后的学生数组返回给前端。
return students;

完整代码如下:

public class Main {
    public static void main(String[] args) {
        Student[] students = new Student[]{
                new Student("张三", 90),
                new Student("李四", 80),
                new Student("王五", 85),
                new Student("赵六", 95)
        };
        
        Arrays.sort(students, (s1, s2) -> s2.getScore() - s1.getScore());
        
        // 将排序后的学生数组返回给前端
        // ...
    }
}

public class Student {
    private String name;
    private int score;
    
    public Student(String name, int score) {
        this.name = name;
        this.score = score;
    }
    
    public String getName() {
        return name;
    }
    
    public void setName(String name) {
        this.name = name;
    }
    
    public int getScore() {
        return score;
    }
    
    public void setScore(int score) {
        this.score = score;
    }
}

要实现过滤出500分以下的学生或只留下男同学,可以在排序后遍历学生数组,根据条件筛选出符合要求的学生,然后将符合要求的学生放入新的数组中返回给前端。

例如,如果要过滤出500分以下的学生,可以在排序后遍历学生数组,找到分数小于等于500的学生,然后将这些学生放入新的数组中返回给前端。具体代码实现如下:

// 定义新的数组
Student[] filteredStudents = new Student[students.length];
int count = 0;

// 遍历学生数组,找到分数小于等于500的学生
for (Student student : students) {
    if (student.getScore() <= 500) {
        filteredStudents[count++] = student;
    }
}

// 将新的数组返回给前端
return filteredStudents;

如果要只留下男同学,可以在排序后遍历学生数组,找到性别为男的学生,然后将这些学生放入新的数组中返回给前端。具体代码实现如下:

// 定义新的数组
Student[] filteredStudents = new Student[students.length];
int count = 0;

// 遍历学生数组,找到性别为男的学生
for (Student student : students) {
    if (student.getGender() == Gender.MALE) {
        filteredStudents[count++] = student;
    }
}

// 将新的数组返回给前端
return filteredStudents;

需要注意的是,如果新的数组长度不足原数组长度,返回的数组中可能会存在空值,需要在前端处理空值的情况。

Edited 6月 30, 2023 by 小傅哥
指派人
分配到
无
里程碑
无
分配里程碑
工时统计
无
截止日期
无
标识: KnowledgePlanet/doc#18
渝ICP备2023009037号

京公网安备11010502055752号

网络110报警服务 Powered by GitLab CE v13.7
开源知识
Git 入门 Pro Git 电子书 在线学 Git
Markdown 基础入门 IT 技术知识开源图谱
帮助
使用手册 反馈建议 博客
《GitCode 隐私声明》 《GitCode 服务条款》 关于GitCode
Powered by GitLab CE v13.7