1700445629
1700445630
static class Person implements Comparable<Person>{
1700445631
1700445632
//身高
1700445633
1700445634
private int height;
1700445635
1700445636
public Person(int_age){
1700445637
1700445638
height=_age;
1700445639
1700445640
}
1700445641
1700445642
/*height的getter/setter方法省略*/
1700445643
1700445644
//按照身高排序
1700445645
1700445646
public int compareTo(Person o){
1700445647
1700445648
return height-o.height;
1700445649
1700445650
}
1700445651
1700445652
}
1700445653
1700445654
这是set的简单用法,定义一个Set集合,之后放入两个元素,虽然175后放入,但是由于是按照升序排列的,所以输出的结果应该是175在前,180在后,结果如下:
1700445655
1700445656
身高:175
1700445657
1700445658
身高:180
1700445659
1700445660
这没有问题,随着时间的推移,身高175cm的人长高了10cm,而180cm却保持不变,那排序的位置应该改变一下吧,看代码:
1700445661
1700445662
public static void main(String[]args){
1700445663
1700445664
SortedSet<Person>set=new TreeSet<Person>();
1700445665
1700445666
//身高180CM
1700445667
1700445668
set.add(new Person(180));
1700445669
1700445670
//身高175CM
1700445671
1700445672
set.add(new Person(175));
1700445673
1700445674
//身高最矮的人大变身
1700445675
1700445676
set.frst().setHeight(185);
1700445677
1700445678
for(Person p:set){
[
上一页 ]
[ :1.700445629e+09 ]
[
下一页 ]