treemap牵扯出的数据结构入门,用二叉树保存我们的数据,stack,老司机的学习方法

image.png

今天我们来了解下TreeMap


image.png

从上图看出TreeSet是通过TreeSet实现 横排的都是一类接口
上节课我们通过HashMap向集合中加入了自定义对象类型的一堆数据,发现数据是不能够排序的,要手工排序比较麻烦
然而TreeMap默认支持排序
接下来测试一下代码 MyIndex


image.png

运行结果
image.png

可以看出它为我们输出做了排序 按照字母进行的排序 如果传入的是数字会按照数字大小进行排序

但是一般我们会自定义排序 不会这么直接的排序
点击TreeMap进入源码可以看出 支持传入Comparator进行自定义排序的 而HashMap则不可以


image.png

下面演示一下代码
image.png

运行结果
image.png

上面代码实现了按照字符长度进行排序 但是结果却出现了覆盖现象 对字符长度相等的lis没有输出
返回值如果等于0,TreeMap中会将值覆盖掉一个
如何解决呢?
在比较的时候加上字符串的ascll 码值进行比较
image.png

运行结果
image.png

为什么TreeMap可以实现排序的这种操作呢?
image.png

这时候问题来了?什么是红黑树 什么是树 树在我们的数据结构中承担了什么样的低位


image.png

我们之前学了ArrayList 是一个数组结构 学过LinkedList是个链表结构 今天学的TreeMap是个树行结构
image.png

这些结构,无外乎就是用来保存我们的数据,供我们方便的使用
下面我们学习一下树结构
image.png

接下来用代码演示一下如何保存数据到树中 并输出出来
接下来我们创建一个包叫做Tree里面写入BTree.java(表示二叉树)
目录如下
image.png

BTree代码如下
image.png

image.png

MyIndex测试代码如下
image.png

打印结果如下
image.png

思考一下以下问题
image.png
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 基于树实现的数据结构,具有两个核心特征: 逻辑结构:数据元素之间具有层次关系; 数据运算:操作方法具有Log级的平...
    yhthu阅读 4,379评论 1 5
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,419评论 11 349
  • 一、基本数据类型 注释 单行注释:// 区域注释:/* */ 文档注释:/** */ 数值 对于byte类型而言...
    龙猫小爷阅读 4,305评论 0 16
  • 工作以后出于兴趣在家乡城市发起了一个英语沙龙,隔三差五把一些喜欢英语交流的小伙伴聚集在一起,练练口语;于是在这个过...
    大射手Cathy阅读 1,025评论 0 10
  • 1、什么是CSS hack 不同厂商的浏览器,比如Internet Explorer,Safari,Mozilla...
    字母31阅读 735评论 0 1