Day19~23数据结构、Set、Map-2019-04-19

数据结构

  • 线性表

    • 顺序表
    • 链表
  • 队列

  • 树:
    二叉树查找树:增加节点、删除节点、遍历(递归、非递归)、根据遍历建树、求二叉树的高度

  • 排序:
    插入排序
    选择排序
    冒泡排序
    希尔排序
    快速排序
    堆排序
    归并排序

  • 查找:
    折半查找
    折半查找的变种


Set

Set 接口:
    一个不包含重复元素的 collection. 此接口模仿了数学上的 set 抽象

HashSet (实现子类:
    它不保证 set 的迭代顺序;特别是它不保证该顺序恒久不变。此类允许使用 null 元素。
    当数组进行扩容或者缩容的时候,元素的位置可能发生改变。
添加功能依赖于两个方法:
    int hashCode()
    boolean equals(Object obj)

LinkedHashSet (实现子类:
    具有可预知迭代顺序的 Set 接口的哈希表和链接列表实现。
    插入的顺序就是加集合的迭代顺序
    由链表保证元素有序
    由哈希表保证元素唯一

TreeSet:
    使用元素的内在顺序对元素进行排序,或者根据创建 set 时提供的 Comparator 进行排序,
    具体取决于使用的构造方法.

    构造方法:
        TreeSet()  构造一个新的空 set,该 set 根据其元素的自然顺序进行排序。
        TreeSet(Comparator<? super E> comparator)
            构造一个新的空 TreeSet,它根据指定比较器进行排序。
    Comparator:
        int compare(T o1,T o2)
        比较用来排序的两个参数。根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数。

    注意事项:
        如果使用无参构造方法,就对元素进行自然排序,如果有传入一个比较器,就使用比较器的比较方法进行排序。
        treeSet不能存null;

Collection 
    |-- List
        |-- ArrayList   底层是数组,增删慢,查找块,线程不安全,效率高
        |-- LinkedList  底层是链表,增删快,查找慢,线程不安全,效率高
        |-- Vector      底层是数组,增删慢,查找块,线程安全,效率低
        
    |-- Set
        |-- HashSet 底层是HashMap, 和存储元素的hashCode()和equals()相关, 不保证 set 的迭代顺序
            |-- LinkedHashSet 元素有序(插入的顺序), 由链表保证元素有序, 由哈希表保证元素唯一
        |--TreeSet 底层是TreeMap, TreeMap的底层是红黑树。它是怎么保证元素的有序性和唯一性的呢?
            如果没有传入一个比较器,默认用自然排序
            如果传入了一个比较器,就用比较器提供的比较方法
            如果用比较方法返回值是0, 说明这两个元素是“相等”的。TreeMap不能存null值。

Map:
Map接口和Collection接口的不同
    Map是双列的,Collection是单列的
        Map是成双成对的, Collection 单身狗
    Map的键唯一,Collection的子体系Set内的元素是唯一的
    Map集合的数据结构只针对Key有效,跟值无关
        Map的侧重点是Key.
   Collection集合Set的数据结构是针对元素有效
    Entry<K, V>
    方法:
        增:
             V put(K key, V value)
             void putAll(Map<? extends K,? extends V> m)
        删:
            clear()
             V remove(Object key)
        改:
            V put(K key, V value)
        查:
            containsKey(Object key)
            containsValue(Object value)
            V get(Object key) // 根据Key查找Value值
        获取Map集合的属性:
            boolean isEmpty()
            int size()
        遍历:
            Set<Map.Entry<K,V>> entrySet()
            Set<K> keySet()
            Collection<V> values()
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,386评论 6 479
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,939评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,851评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,953评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,971评论 5 369
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,784评论 1 283
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,126评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,765评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,148评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,744评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,858评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,479评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,080评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,053评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,278评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,245评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,590评论 2 343

推荐阅读更多精彩内容

  • 一些概念 数据结构就是研究数据的逻辑结构和物理结构以及它们之间相互关系,并对这种结构定义相应的运算,而且确保经过这...
    Winterfell_Z阅读 5,654评论 0 13
  • 树(续) 二叉树 二叉排序树 二叉排序树,又叫二叉查找树,它或者是一棵空树;或者是具有以下性质的二叉树: 若它的左...
    liuzhangjie阅读 1,139评论 0 0
  • 1)这本书为什么值得看: Python语言描述,如果学的Python用这本书学数据结构更合适 2016年出版,内容...
    孙怀阔阅读 12,438评论 0 15
  • 1. 链表 链表是最基本的数据结构,面试官也常常用链表来考察面试者的基本能力,而且链表相关的操作相对而言比较简单,...
    Mr希灵阅读 1,430评论 0 20
  • 1 我的彩铅学习作业大合集! 从平平无感彩色画,过渡到了富有立体感彩色画,这是一个享受的过程,快乐的学习! 2 我...
    128栀子英阅读 457评论 1 4