Java的List集合对象插入排序

需求背景,在一个循环里,每次循环出一个对象,将这个对象存放到另一个集合中,且另一个集合需要根据对象的某个属性的大小进行排序。
类似如下的集合

//RelateCountMatrixEntity对象,属性如下
private String xAxis;
private String yAxis;
private Integer count;
private double relateScore;
//RelateCountMatrixEntity对象集合
List<RelateCountMatrixEntity> recommandUserList = new ArrayList<>();

比如对Integer count属性进行排序,如果recommandUserList集合的长度不是很长,可以直接使用List里自带的排序方法即可recommandUserList.sort((a, b) -> b.count.compareTo(a.count));。 遗憾的是,这种方式适合int整形的数据,不能适用double relateScore这种类型。

一次只产生一个数据,放入一个列表中,并且这个列表最终顺序,插入排序可能是比较优雅的方式。
结合Java的list集合特性,该排序分为三个步骤:

  • 添位置: 首先将待排序的数据直接存放到list中,因为list是一个自增数组,把list集合延长一个位置避免数组越界;然后判断该条数据是否首次插入。
  • 找位置: 因为最后一条数据就是待排序的数据,依次与它前面数据进行比较找到自己合适的位置。
  • 进入位置: 位置找到后,根据位置下标插入数据即可。

提示:这时会想到待排序的数据第一次就插在最后一个位置了,会不会数据冗余;在找位置的时候,倒数第二个数据就把最后一个数据覆盖了ÿ

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值