Java实现集合排序(以学生成绩排序为例)

信息学院年终评定奖学金,需要对整个年级的学生按照平均分数进行排名。 要求:根据输入的学号和平均成绩,按照平均成绩降序输出学号,如果平均成绩相同,按照输入的顺序输出。

比如将一个List<Student>排序,则有两种方式:
1:Student实现Comparable接口:
2:给排序方法传递一个Comparator参数:

- 本文以对Student对象集合为例进行排序
Java通过Collections.sort(List<Student> stuList)和Collections.sort(List<Student> stuList,Comparator c)两种方法实现排序。

用Collections.sort(List list) 方法实现排序:

step1: 确保Student类实现了Comparable接口,并重写了compareTo()方法。

step2:调用Collections.sort(List list) 方法进行排序。

package Test;

/*3 .信息学院年终评定奖学金,需要对整个年级的学生按照平均分数进行排名。
要求:根据输入的学号和平均成绩,按照平均成绩降序输出学号,如果平均成绩相同,按照输入的顺序输出。
*/
import java.util.ArrayList;
import java.util.Collections;
import java.util.Scanner;

public class Test_3 {

class Student implements Comparable<Student> {
	private String sno;
	private int score;

	public Student(String sno, int score) {
		this.sno = sno;
		this.score = score;
	}

	public String getSno() {
		return sno;
	}

	public void setSno(String sno) {
		this.sno = sno;
	}

	public int getScore() {
		return score;
	}

	public void setScore(int score) {
		this.score = score;
	}

	public int compareTo(Student s) {
//	int compareTo(T o)将此对象与指定的对象进行比较以进行排序。 返回一个负整数,零或正整数,因为该对象小于,等于或大于指定对象。
		return s.getScore() - this.getScore();
	}
public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		ArrayList<Student> students = new ArrayList<Student>();
		for (int i = 1; i <= n; i++) {
			Student student = new Student(sc.next(), sc.nextInt());
			students.add(student);
		}
		Collections.sort(students);
		for (Student student : students) {
			System.out.println(student.getSno());
		}
	}
}

}

用Collections.sort(List list,Comparator c) 方法实现排序:

该方法传入一个比较器,用于比较各元素的大小。该方法不需要元素实现Comparable接口,但需要一个实现Comparator接口的实现类来实例化一个比较器,注意,这里的Comparator是一个接口而非类。这里通常采用匿名内部类的方法。

public class Student {
	private String id;
	private double grade;
	public Student(String id, double grade) {
		this.id = id;
		this.grade = grade;
	}
	public Student() {}
	public String getId() {
		return this.id;
	}
	public void setId(String id) {
		this.id = id;
	}
	public double getGrade() {
		return this.grade;
	}
	public void setGrade(double grade) {
		this.grade = grade;
	}
	public String toString() {
		return "Student [id=" + id + ", grade=" + grade + "]";
	}
}




import java.util.Collections;
import java.util.Comparator;
import java.util.LinkedList;
import java.util.List;
import java.util.Scanner;
 
public class Sop {
	public static void main(String[] args)
	{
		List<Student>list=new LinkedList<Student>();
		int n;
		Scanner cin=new Scanner(System.in);
		System.out.println("输入学生的总人数");
		n=cin.nextInt();
		System.out.println("输入学生的学号,平均成绩");
		for(int i=0;i<n;i++)
		{
			String id=cin.next();
			double grade=cin.nextDouble();
			Student student=new Student(id, grade);
			list.add(student);
		}
 
		cin.close();
       Collections.sort(list,new Comparator<Student>()
       {
 
            public int compare(Student stu1, Student stu2)
            {
 
               return (int) (stu2.getGrade()-stu1.getGrade());
 
            }      
 
       }
       );
       
       for(int i=0;i<list.size();i++)
       {
    	   //System.out.println(list.get(i).getId()+" "+list.get(i).getGrade());
    	   System.out.println(list.get(i));
       }
}
}

 

  • 6
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
1、创建类实现基本对象和他们关系的管理,包括学生、教学班、课程、成绩、教师等。使用集合框架存储所有对象。学生至少包含学号、姓名、性别等信息。教学班至少包含教师、课程名字、总人数、教学班号、开课学期等信息。课程至少包含课程编号、课程名字等信息。教师至少包含教师编号、姓名等信息。 2、随机生成学生,数量不少于100。一个教学班有一个教师上一门课程,教学班的学生数量不少于20。课程数量不少于3门。教师数量不少于6个。一门课至少有两个老师上课。每个学生选择至少选择3门课程。一个学生在一个教学班上一门课,考试后取得一个成绩。一门课的成绩构成有4部分构成,包括平时成绩、期中考试、实验成绩和期末考试成绩,然后计算出总成绩成绩随机生成,均为整数。 3、分阶段模拟教学过程。例如执行一个命令,可以生成一个教学班的所有学生的平时成绩。第一步,生成初始化数据,包括教师,学生、课程,教学班等;第二步,学生选课,随机进行,为每门课程的教学班安排学生。第三步,获得平时成绩,获得期中成绩,获得实验成绩,获得期末成绩,最后计算总成绩。 4、能够显示一个教学班级的学生,可以根据学号排序,可以根据成绩排序。可以通过名字查询成绩,可以按照各科成绩和总成绩进行排名显示,可以统计各课程学生成绩的分数段分布。 5、可以实现自己的扩展功能。注意类和类之间的关系。充分利用继承,多态等特性,使用上抽象类,接口,泛型,内部类等设计元素。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值