【2022初春】【笔记】自定义类排序写法

自定义排序函数
1.定义要排序的类
2.写个类继承排序接口,重写排序函数
3.在主类里调用排序函数
String自带compareTo是按字符顺序比较

import java.util.*;


public class Main{

    public static void  main(String[] args){
        Scanner sc = new Scanner(System.in);
        String sn = sc.nextLine();
        String str1 = sc.nextLine();
        String str2 = sc.nextLine();
        int n = Integer.valueOf(sn);
        String[] sh = new String[n];
        int[] h = new int[n];
        String[] s = new String[n];
        sh = str1.split(" ");
        s = str2.split(" ");
        for(int i=0; i<n; i++) h[i] = Integer.valueOf(sh[i]);
        List<User> users = new ArrayList<>();
        for(int i=0; i<n; i++) {
            User u = new User(h[i],s[i]);
            users.add(u);
        }
        Collections.sort(users,new UserComparator());
        int k=0;
        for (User user : users) {
            if(k==n-1) System.out.print(user.getName());
            else System.out.print(user.getName() + " ");
            k++;
        }
    }

}
class User{
    int high;
    String name;

    public User(int high, String name) {
        this.high = high;
        this.name = name;
    }

    public void setHigh(int high) {
        this.high = high;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getName() {
        return name;
    }
    public int getHigh() {
        return high;
    }
    /*int compareTo(User use){
        return high - use.getHigh();
    }*/

}
class UserComparator implements Comparator {
    @Override
    public int compare(Object o1, Object o2) {
        User user1 = (User) o1;
        User user2 = (User) o2;

        if (user1.getHigh() > user2.getHigh()) {
            return 1;
        } else if (user1.getHigh() < user2.getHigh()) {
            return -1;
        } else {
            return user1.getName().compareTo(user2.getName());
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值