天天看点

Java基础-TreeSet与Java自定义类型的排序

演示TreeSet对String是可排序的

TreeSet无法对自定义类型进行排序

比较规则怎么写

自平衡二叉树结构

实现比较器接口

Collections工具类

1.TreeMap集合底层实际上是一个TreeMap

2.TreeMap集合底层是一个二叉树

3.放到TreeSet集合中的元素,等同于放到TreeMap集合key部分了

4.TreeSet集合中的元素,无序不可重复,但是可以按照元素的大小顺序自动排序

称为:可排序集合

例如:编写程序从数据库中取出数据,在页面展示用户信息的时候按照生日升序或者降序,

这个时候可以使用TreeSet集合,因为TreeSet集合放进去,拿出来就是有序的。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

Java基础-TreeSet与Java自定义类型的排序

TreeSet可以对自定义类型进行排序?

以下程序中,对于Person类来说,无法排序,因为没有指定Person对象之间的比较规则。谁大谁小并没有说明。

24

25

26

27

28

29

30

出现这个错误的原因是

Person类没有实现java.lang,Comparable接口

//放在TreeSet集合中的元素需要实现java.lang.Comparable接口

//并且实现compareTo方法,equals可以不写

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

//需要在这个方法中编写比较的逻辑,或者说比较的规则,按照什么进行比较。

//k.compareTo(t.key)

//拿着参数k和集合中的每个k进行比较,返回值可能是>0,<0,=0

//比较规则最终还是程序员实现的:例如按照年龄升序,或者按照年龄降序

先按照年龄升序,如果年龄一样的再按照姓名升序

1.自平衡二叉树,遵循左小右大的原则存放

2.遍历二叉树的时候有三种方式

前序遍历:根左右

中序遍历:左根右

后序遍历:左右根

注意:前中后说的是根的位置

3.TreeSet集合和TreeMap集合采用的是中序遍历方式,即左根右。他们是自平衡二叉树

100 200 50 60 80 120 140 130 135 180 666

TreeSet集合中元素可排序的第二种方式,使用比较器的方式

我们可以使用匿名内部类的方式

可以使用匿名内部类的方式(这个类没有名字,直接new接口)

最终的结论,放在TreeSet或者TreeMap集合key部分的元素要想做到排序,包括两种方式

第一种:放在集合中的元素实现java.lang.Comparable接口

第二种:在构造TreeSet或者TreeMap集合的时候给它传一个比较器对象。

Comparable和Comparator怎么选择呢?

当比较规则不会发生改变的时候,或者说当比较规则只有1个的时候,建议实现Comparable接口

如果比较规则有多个,并且需要多个比较规则之间频繁切换,建议使用comparator接口

comparator接口的设计符合OCP原则。

java.util.Collections集合工具类,方便集合的操作

55

56

57

58

59

60

61

62

Java基础-TreeSet与Java自定义类型的排序