Java对学生成绩排序——通过list.sort()对list进行排序

**【题目】**输入任意(用户,成绩)序列,可以获得成绩从高到低或从低到高的排列,相同成绩。都按先录入排列在前的规则处理。

例示:
jack 70
peter 96
Tom 70
smith 67

从高到低 成绩
peter 96
jack 70
Tom 70
smith 67

从低到高

smith 67

Tom 70
jack 70

peter 96

注:0代表从高到低,1代表从低到高
在这里插入图片描述

——对list进行排序时,可以采用sort()方法,集合的sort方法可以出入一个自定义的比较器, 比较器中的 compare方法传入两个参数,返回值是负数时是升序排列,返回值是正数时是降序排列。 list.sort((o1,o2) -> o2.score-o1.score)

import java.util.Scanner;
import java.util.List;
import java.util.ArrayList;
public class Main{
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        while(sc.hasNext()){
            int num = sc.nextInt();
            int sortType = sc.nextInt();//0:从高到低,1:从低到高
            List<Person> list = new ArrayList<>();
            for(int i=0;i<num;i++){
                Person person = new Person(sc.next(),sc.nextInt());//将每一次循环的输入值传入新建的对象中
                list.add(person);//加入该对象
            }
            if(sortType==0){//降序
                list.sort((o1,o2) -> o2.score-o1.score);
            }else{//升序
                list.sort((o1,o2) -> o1.score-o2.score);
            }
            for(Person p:list){
                System.out.println(p.name+" "+p.score);
            }
        }
    }
}

class Person{
    String name;
    int score;
    
    public Person(String name,int score){
        this.name = name;
        this.score = score;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值