zoukankan      html  css  js  c++  java
  • 数据结构

    1、红黑树:

    是一种自平衡的二叉树,

    1. 每个节点都有红色或黑色
    2. 树的根始终是黑色的 (黑土地孕育黑树根, )
    3. 没有两个相邻的红色节点(红色节点不能有红色父节点或红色子节点,并没有说不能出现连续的黑色节点)
    4. 从节点(包括根)到其任何后代NULL节点(叶子结点下方挂的两个空节点,并且认为他们是黑色的)的每条路径都具有相同数量的黑色节点

    瞬间懵逼?了解一下印象就行,开始玩魔方都是要照着魔方公式一点点玩的,多玩几次就熟悉了。红黑树也一样,红黑树有两大操作:

      1. recolor (重新标记黑色或红色)
      2. rotation (旋转,这是树达到平衡的关键)

    时间复杂度O(logN) 查找、插入、删除

    平衡二叉树是左边子节点比父节点小,右边子节点比父节点大,左节点深度和右节点深度相同,或者右节点深度跟左节点深度相差1,比较严苛,需要不断的变化,使得二叉树平衡,损坏性能CPU。

    红黑树是相对宽松的平衡二叉树,最差情况下,右节点深度跟左节点深度相差2倍

    红黑树,超强动静图详解,简单易懂 - 知乎 (zhihu.com)

    2、java集合容器

    ConcurrentHashMap

    3、排序算法

    常见的排序算法——常见的10种排序 - sc_FlyingDreams - 博客园 (cnblogs.com)

    冒泡排序

      每轮依次比较相邻数字的大小,将大数字向后移动,最终达到有序状态。

    选择排序

      每轮比较将当前值与未排序的值依次比较,找出最小的值,将其与当前值交换,达到有序状态

    插入排序

      依次遍历数组,每次将当前值插入已经排好序的数组中,最终达到有序状态。

    希尔排序

      将整个数组划分为不同的组,一般以n/2的对应划分,将所有组中的元素分别进行插入排序,  排好序后再次以,(n/2)/2,....1的划分并排序,最终达到有序。

    归并排序

      将数组划分为不同的组,依次对所有的组排序,最后再对排好序的组进行合并,采用了递归的思想,可以自顶向下及自底向上

    快速排序

      将数组根据某一数值划分为两个独立部分,一部分比关键字小,一部分比关键字大,然后再分别对这两部分进行排列,达到整个序列有序。 

    堆排序

      将数组元素组织为堆的结构,包括大顶堆及小顶堆,依次取出头部元素,调整堆结构,最终达到有序。

    计数排序

      要求输入元素是确定范围且范围较小的,分配最大值与最小值之差的大小的空间,将出现的数字放入指定位置,如果重复则加1.放完后取出就有序了

    桶排序

      计数排序升级版,最好应用于均匀分布的数据,将数据分配到有限数量的桶中,单个桶再排序,如果数据都进了一个桶中,排序就基本没有用了。

    基数排序

      利用数字的位数,先按地位数字,将数组元素放入10个桶中,这样最后一位就拍好了,在取出,按次低位进行排序,在取出,值到最高位,再取出就有序了。

     

  • 相关阅读:
    恢复计算机崩溃数据的五款最佳Linux发行版
    不敢想象!Vim使用者的“大脑”竟是这样
    开发者和系统管理者最喜爱的开源工具Vim 起步学习的五个技巧
    .NET程序与CA对接一直提示重定向
    覆盖原有div或者Input的鼠标移上去描述
    IOS9以上如何导入铃声并设置
    c# 动态调用webserver
    没有终结点在侦听可以接受消息的*这通常是由于不正确的地址或者 SOAP操作导致的
    url 参数的加号变成空格处理
    在git 服务器挂载、创建新的项目、克隆新的项目
  • 原文地址:https://www.cnblogs.com/baldprogrammer/p/14035871.html
Copyright © 2011-2022 走看看