【算法】红黑树

一、红黑树介绍

红黑树是一种自平衡二叉查找树,是在计算机科学中用到的一种数据结构,典型的用途是实现关联数组。

红黑树是在1972年由Rudolf Bayer发明的,当时被称为平衡二叉B树(symmetric binary B-trees)。后来,在1978年被 Leo J. Guibas 和 Robert Sedgewick 修改为如今的“红黑树”。

红黑树是一种特化的AVL树(平衡二叉树),都是在进行插入和删除操作时通过特定操作保持二叉查找树的平衡,从而获得较高的查找性能。它虽然是复杂的,但它的最坏情况运行时间也是非常良好的,并且在实践中是高效的:它可以在O(log n)时间内做查找,插入和删除,这里的n 是树中元素的数目。

红黑树的每个红色结点的两个子结点都是黑色,从任一结点到其每个叶子的所有路径都包含相同数目的黑色结点。

以上信息仅供参考,建议查阅专业书籍或者咨询专业人士了解更多信息。

二、红黑树在什么情况下会变得不平衡

红黑树在以下情况下会变得不平衡:

  1. 插入操作:当插入一个新的节点时,如果插入后的树不再满足红黑树的定义,那么树就会变得不平衡。例如,新插入的节点颜色为红色,而它的父节点颜色也为红色,这就会违反红黑树的定义,导致树变得不平衡。
  2. 删除操作:当删除一个节点时,如果删除后的树不再满足红黑树的定义,那么树也会变得不平衡。例如,当删除一个红色节点后,其父节点也必须为红色,但如果其父节点也是红色,那么就会违反红黑树的定义,导致树变得不平衡。

为了保持红黑树的平衡性,需要在插入和删除操作时进行一些特定的调整。这些调整包括重新着色节点和重新排列树结构,以确保红黑树的平衡性得到维护。

三、红黑树的定义是什么

红黑树是一种自平衡二叉查找树,是在计算机科学中用到的一种数据结构。它是每个节点都带有颜色属性的二叉查找树,颜色为红色或黑色。

红黑树满足以下性质:

  1. 每个节点要么是红色,要么是黑色。
  2. 根节点是黑色。
  3. 每个叶节点(NIL节点,空节点)是黑色。
  4. 如果一个节点是红色的,则它的两个子节点都是黑色。
  5. 从任一节点到其每个叶节点的所有路径都包含相同数目的黑色节点。

以上信息仅供参考,建议查阅专业书籍或者咨询专业人士了解更多信息。

四、红黑树和AVL树有哪些区别

红黑树和AVL树的区别主要体现在以下几个方面:

  1. 平衡的实现机制:红黑树通过颜色和旋转来实现平衡,而AVL树则通过左右子树的高度差来决定旋转。
  2. 插入效率:红黑树在插入时,由于它只要求部分地达到平衡要求,所以其旋转次数比AVL树要少,因此插入效率更高。
  3. 统计性能:红黑树能够以O(log2n)的时间复杂度进行搜索、插入、删除操作,而AVL树的性能与其应用场景有关,在查找效率上通常较高。

以上区别仅供参考,建议查阅专业书籍或者咨询专业人士了解更多信息。

五、红黑树的优缺点

红黑树的优点主要包括:

  1. 查找、插入和删除操作的平均和最坏情况时间复杂度都是 O(log n),这使得红黑树在大型数据集上的性能非常好。
  2. 红黑树的平衡性使得它对于一些动态插入、删除元素的应用场景非常适合。
  3. 红黑树在应用中非常广泛,常被用于各种高性能的数据结构库,例如 STL 中的 set 和 map。

红黑树的缺点主要包括:

  1. 相比于其他数据结构,红黑树的实现比较复杂,需要维护节点的颜色和平衡。
  2. 在进行大量插入和删除操作的情况下,可能会造成频繁的树重构,影响性能。
  3. 红黑树的实现需要额外的空间来存储颜色信息,这意味着相对于其他数据结构,红黑树的空间占用率可能会更高。

总的来说,红黑树是一种高效、自平衡的数据结构,特别适合在需要频繁进行动态插入和删除操作的场景中使用,例如实现高性能的集合和映射。但是在一些空间受限的场景中,可能会有更好的选择。

六、举个例子

以下是一个红黑树的例子:

假设我们有一个红黑树,其中包含了整数1到11,按照从小到大的顺序插入。在插入过程中,我们需要遵守红黑树的定义和性质,通过旋转和重新着色来保持树的平衡。

插入数字1时,因为树为空,所以直接创建一个黑色的根节点1。

接着插入数字2,因为2比1大,所以将2作为1的右子节点,并将其颜色设置为红色。此时树仍然满足红黑树的定义。

然后插入数字3,因为3比2大,所以将3作为2的右子节点,并将其颜色设置为红色。此时,节点2和节点3都是红色,违反了红黑树的定义。为了解决这个问题,我们需要进行旋转和重新着色操作,将节点2变为黑色,节点1变为红色,然后对节点1进行右旋操作。此时树重新恢复平衡。

接下来继续插入数字4到11,每次插入时都根据红黑树的定义进行相应的调整,包括旋转和重新着色操作。最终得到的红黑树就是一个平衡的二叉查找树,其中包含了数字1到11。

这个例子展示了红黑树在插入过程中的自平衡特性,通过旋转和重新着色操作来保持树的平衡性。这种平衡性确保了红黑树在查找、插入和删除操作上的高效性能。

七、红黑树为什么可以保持平衡

红黑树之所以可以保持平衡,是因为它遵守了红黑树的定义和性质。

首先,红黑树是一种平衡的二叉查找树,它的每个节点要么是红色,要么是黑色。在插入和删除操作中,红黑树通过旋转和染色来保持平衡。

其次,红黑树的核心操作是旋转和染色。旋转操作分为左旋和右旋,它们可以帮助恢复树的平衡性。染色操作则是通过改变节点的颜色来保持红黑树的性质。

在插入操作中,如果插入后的树不再满足红黑树的定义,就需要进行旋转和染色操作来恢复平衡。同样地,在删除操作中,如果删除后的树不再满足红黑树的定义,也需要进行旋转和染色操作来恢复平衡。

最后,红黑树的平衡性是通过颜色和旋转来实现的。每个节点都带有颜色属性,并且每个红色节点都必须有两个黑色的子节点(或空子节点)。这种平衡性保证了从根节点到每个叶节点的所有路径都包含相同数目的黑色节点,从而确保了查找、插入和删除操作的效率。

综上所述,红黑树通过遵守红黑树的定义和性质,通过旋转和染色操作来保持平衡,从而实现了高效的查找、插入和删除操作。

八、红黑树的实现原理是什么

红黑树的实现原理是基于二叉查找树,并通过引入额外的颜色和旋转操作来保持树的平衡。

首先,红黑树是一种自平衡的二叉查找树,它满足二叉查找树的性质,即对于树中的每个节点,其左子树中的所有节点的值都小于该节点的值,右子树中的所有节点的值都大于该节点的值。

为了保持平衡,红黑树引入了节点颜色的概念,每个节点都有一个颜色属性,可以是红色或黑色。同时,红黑树还满足以下性质:

  1. 节点是红色或黑色。
  2. 根节点是黑色。
  3. 每个叶节点(NIL节点,空节点)是黑色。
  4. 如果一个节点是红色的,则它的两个子节点都是黑色。
  5. 从任一节点到其每个叶节点的所有路径都包含相同数目的黑色节点。

在插入操作中,当插入一个新的节点时,红黑树会按照二叉查找树的规则进行插入,并将新插入的节点颜色设置为红色。然后,根据红黑树的性质进行调整,包括旋转和重新着色操作,以确保树仍然满足红黑树的定义。

在删除操作中,红黑树会先按照二叉查找树的规则进行删除,然后进行相应的调整来恢复平衡。这可能包括旋转和重新着色操作。

通过遵守这些规则和性质,红黑树能够在插入和删除操作时保持平衡,从而实现高效的查找、插入和删除操作。这种平衡性确保了红黑树在大型数据集上的性能非常好,使其成为许多数据结构库中的首选数据结构之一。

九、一个红黑树C语言用例

#include <stdio.h>  
#include <stdlib.h>  
  
// 定义红黑树节点结构体  
typedef struct node {  
    int data;           // 节点存储的数据  
    int color;          // 节点颜色,0表示黑色,1表示红色  
    struct node *left;  // 左子节点  
    struct node *right; // 右子节点  
} Node;  
  
// 创建新节点  
Node* create_node(int data) {  
    Node *new_node = (Node*)malloc(sizeof(Node));  
    new_node->data = data;  
    new_node->color = 0; // 初始化为黑色  
    new_node->left = NULL;  
    new_node->right = NULL;  
    return new_node;  
}  
  
// 插入新节点  
Node* insert(Node *root, int data) {  
    if (root == NULL) {  
        return create_node(data); // 如果树为空,创建新节点作为根节点  
    }  
  
    if (data < root->data) {  
        root->left = insert(root->left, data); // 在左子树中插入新节点  
    } else if (data > root->data) {  
        root->right = insert(root->right, data); // 在右子树中插入新节点  
    } else { // 如果要插入的数据已经存在,返回NULL  
        return NULL;  
    }  
  
    // 如果插入后违反了红黑树的性质,需要进行调整  
    if (is_red(root->right)) { // 如果右子节点是红色,需要进行左旋操作  
        root = rotate_left(root);  
    }  
    if (is_red(root->left) && !is_red(root->right)) { // 如果左子节点是红色,右子节点是黑色,需要进行右旋操作  
        root = rotate_right(root);  
    }  
    if (is_red(root->left) && is_red(root->right)) { // 如果左右子节点都是红色,需要进行染色操作  
        flip_colors(root);  
    }  
  
    return root; // 返回根节点指针,用于后续操作  
}  
  
// 判断当前节点是否为红色  
int is_red(Node *node) {  
    if (node == NULL) { // 如果节点为空,返回0(黑色)  
        return 0;  
    } else { // 如果节点不为空,判断颜色是否为红色  
        return node->color == 1;  
    }  
}  
  
// 进行左旋操作,将当前节点旋转到左边,返回新的根节点指针  
Node* rotate_left(Node *z) {  
    Node *y = z->right; // 保存右子节点指针,用于后续操作  
    z->right = y->left; // 将右子节点的左子节点设为当前节点的右子节点(作为旋转后新的左子节点)  
    y->left = z; // 将当前节点设为旋转后右子节点的左子节点(作为旋转后新的右子节点)  
    z->color = y->color; // 将当前节点的颜色设为旋转后右子节点的颜色(用于后续染色操作)  
    y->color = 1 - z->color; // 将旋转后右子节点的颜色设为当前节点的颜色(用于后续染色操作)  
    return y; // 返回新的根节点指针(旋转后的根节点)  
}

十、红黑树的插入操作和删除操作的时间复杂度是多少

插入一个节点的时间复杂度是O(log n),因为红黑树是一种平衡二叉查找树,它可以在O(log n)时间内做查找、插入和删除,这里的n是树中元素的数目。在插入过程中,如果插入的节点不是根节点,那么它会根据红黑树的性质进行旋转和染色操作,以保证树的平衡性。这些操作的时间复杂度都是O(log n)。因此,插入一个节点的时间复杂度也是O(log n)。

十一、红黑树和其他BTS树的区别是什么

红黑树和B树在多个方面存在差异。

  1. 平衡性:红黑树是一种自平衡二叉查找树,通过旋转和染色操作保持树的平衡性,从而确保高效的查找、插入和删除操作。而B树是一种多路搜索树,它的平衡性没有红黑树严格,但具有更强的鲁棒性。
  2. 节点颜色:红黑树的节点具有颜色属性,红色和黑色两种。而B树的节点没有颜色属性。
  3. 查找效率:由于红黑树的平衡性更好,其查找效率通常比B树更高。在红黑树中,查找的时间复杂度为O(log n),而在B树中,查找的时间复杂度为O(log n + k),其中k为关键字数量。
  4. 应用场景:红黑树常用于实现关联数组、动态集合和查找表等数据结构。而B树则更常用于数据库和文件系统中,因为B树的节点可以包含多个关键字和子节点,能够更有效地利用磁盘等外部存储设备的特性。

综上所述,红黑树和B树在平衡性、节点颜色、查找效率和应用场景等方面存在差异。

十二、哪种树更适合于数据索引

红黑树和B树都可以用于数据索引,但它们适用于不同的场景。

红黑树是一种自平衡的二叉查找树,它可以确保查找、插入和删除操作的效率。由于红黑树的平衡性较好,它在处理需要频繁进行查找和更新操作的数据集时表现较好。例如,关联数组、动态集合和查找表等数据结构通常使用红黑树来实现。

B树是一种多路搜索树,它适用于磁盘或其他辅助存储设备上的索引和文件系统。B树的节点可以包含多个关键字和子节点,这使得它更适合于处理大型数据集,特别是在磁盘读写操作方面具有较高的效率。因此,B树在数据库和文件系统中被广泛使用。

总的来说,如果需要频繁进行查找和更新操作,且数据集较小,可以使用红黑树作为索引。如果需要处理大型数据集,特别是在磁盘读写方面具有较高效率的场景下,可以使用B树作为索引。

十三、那在实际应用中,哪一种更适合

在实际应用中,选择红黑树还是B树作为索引取决于具体的应用场景和需求。

如果需要频繁进行查找和更新操作,且数据集较小,红黑树是一种很好的选择。它具有较好的平衡性和查找效率,可以快速定位目标数据,并且适用于需要关联数组、动态集合和查找表等数据结构的情况。

如果需要处理大型数据集,特别是在磁盘读写操作方面具有较高效率的场景下,B树是更好的选择。B树的节点可以包含多个关键字和子节点,使得它更适合于处理大型数据集,并且适用于数据库和文件系统等需要高效磁盘访问的应用。

总之,需要根据具体的应用场景和需求来选择合适的索引结构。在某些情况下,红黑树可能更适合,而在其他情况下,B树可能更为合适。

十四、一个红黑树C语言应用

创建一个红黑树涉及到多个概念和函数实现累积起来比较复杂,至关重要的是实现树节点插入、删除、旋转和重新着色的操作。下面为您简要介绍如何用C语言创建一个基本的红黑树,并展示其中的一些核心功能。此红黑树的实现仅用于学习目的,没有经过充分测试和优化。

下面是一个简单的C语言红黑树实现的框架:

#include <stdio.h>
#include <stdlib.h>

typedef enum { RED, BLACK } Color;

typedef struct Node {
    int data;
    Color color;
    struct Node *left, *right, *parent;
} Node;

typedef struct RBTree {
    Node *root;
} RBTree;

Node* createNode(int data) {
    Node *newNode = (Node*)malloc(sizeof(Node));
    newNode->data = data;
    newNode->color = RED;
    newNode->left = NULL;
    newNode->right = NULL;
    newNode->parent = NULL;
    return newNode;
}

RBTree* createRBTree() {
    RBTree *tree = (RBTree*)malloc(sizeof(RBTree));
    tree->root = NULL;
    return tree;
}

// 以下是红黑树操作的伪代码占位
void leftRotate(RBTree *tree, Node *x) {
    // 执行左旋转操作
}

void rightRotate(RBTree *tree, Node *y) {
    // 执行右旋转操作
}

void fixViolation(RBTree *tree, Node *newNode) {
    // 修复红黑树属性的操作
}

void insert(RBTree *tree, int data) {
    Node *newNode = createNode(data);
    // 执行常规的BST插入操作
    // 判断并修复任何可能违反红黑树性质的操作
    fixViolation(tree, newNode);
}

// 主函数,用于测试红黑树
int main() {
    RBTree* tree = createRBTree();

    insert(tree, 10);
    insert(tree, 20);
    insert(tree, 30);
    // ...添加更多节点

    // 执行其他操作,比如删除、查找等

    // 记得释放红黑树所使用的内存
    // destroyRBTree(tree);

    return 0;
}

上面的代码展示了一个非常简略的红黑树创建和插入基础的框架。`leftRotate` 和 rightRotate 函数用于调整树结构以维持红黑树特性。`fixViolation` 函数则用于检查并修正可能出现的违反红黑树性质的情况。

要实现一个完整和健壮的红黑树,你需要补完上述示例中缺失的部分,特别是以下几个重要的部分:

1. 实现 leftRotate 和 rightRotate 函数来执行旋转操作。
2. 函数 fixViolation 中实现修复红黑树属性的具体逻辑(处理双红色违规的四种情况:外侧插入、内侧插入、双侧红色和根节点)。
3. 实现搜索、删除节点以及对应的修复函数。

4. 实现内存释放的函数来避免内存泄漏。

注意,这只是一个框架示例代码,真正实现红黑树涉及到许多细节,包括对多种边界条件的处理,以确保树始终维持平衡。因此,如果你需要一个完整的红黑树实现,可以考虑查找完整的图书或者在线资源,或者直接使用现成的库。 

十五、相关链接

【数据结构】史上最好理解的红黑树讲解,让你彻底搞懂红黑树-CSDN博客

菜鸟nginx源码剖析数据结构篇(四)红黑树ngx_rbtree_t-CSDN博客

漫画算法:什么是红黑树?(适合初学红黑树小白简单易懂)_红白树 举例-CSDN博客

C语言-B树(B-树)的完整实现_b-树 c 实现-CSDN博客

rbtree 红黑树的 C 语言实现-CSDN博客

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/258744.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

R语言——文件读写(三)

目录 一、获取数据 二、读取文件 三、写入文件 四、读写Excel文件 五、读写R格式的文件 参考 一、获取数据 获取数据的三种途径&#xff1a; 1. 利用键盘来输入数据 2. 通过读取存储在外部文件上的数据 3. 通过访问数据库系统来获取数据 edit()&#xff1a;定义一个数…

在使用mapstruct,想忽略掉List<DTO>字段里面的,`data` 字段的映射, 如何写ignore: 使用@IterableMapping

在使用mapstruct,想忽略掉List字段里面的,data 字段的映射, 如何写ignore 代码如下: public interface AssigmentFileMapper {AssigmentFileDTO assigmentFileToAssigmentFileDTO(AssigmentFile assigmentFile);AssigmentFile assigmentFileDTOToAssigmentFile(Assigment…

【Proteus仿真】【Arduino单片机】视力保护仪

文章目录 一、功能简介二、软件设计三、实验现象联系作者 一、功能简介 本项目使用Proteus8仿真Arduino单片机控制器&#xff0c;使LCD1602液晶&#xff0c;DS18B20温度传感器、按键、蜂鸣器、继电器开关、HC05蓝牙模块等。 主要功能&#xff1a; 系统运行后&#xff0c;LCD16…

5252D 5G基站测试仪

01 5252D 5G基站测试仪 产品综述&#xff1a; 5252D多通道综测仪打破了信号发生器进行信号发射、频谱分析仪进行观看频域波形的测试方案&#xff0c;将信号收发融为一体&#xff0c;推动无线通信测试进入全新时代。其独具的多通道收发一体、高性能、全方位测试能力及直观操作…

UE5 runtime模式下自定义视口大小和位置并跟随分辨率自适应缩放

本文旨在解决因UI问题导致屏幕中心位置不对的问题 处理前的现象&#xff1a;如果四周UI透明度都为1&#xff0c;那么方块的位置就不太对&#xff0c;没在中心 处理后的现象&#xff1a; 解决办法&#xff1a;自定义大小和视口偏移 创建一个基于子系统的类或者蓝图函数库(什么类…

链表对象的封装

前言 前面我自己写了一个对链表对象的封装&#xff0c;现在看来&#xff0c;确实还得是大佬的封装思路更加完善 前言知识介绍 __init__方法 __init__方法是Python中的一个特殊方法&#xff0c;用于初始化一个新对象。当一个类的实例被创建时&#xff0c;__init__方法会被自…

【数据结构和算法】 K 和数对的最大数目

其他系列文章导航 Java基础合集数据结构与算法合集 设计模式合集 多线程合集 分布式合集 ES合集 文章目录 其他系列文章导航 文章目录 前言 一、题目描述 二、题解 2.1 方法一&#xff1a;双指针排序 三、代码 3.1 方法一&#xff1a;双指针排序 3.2 方法二&#xff1…

107基于matlab的模糊推理系统(ANFIS)的时间序列预测

基于matlab的模糊推理系统&#xff08;ANFIS&#xff09;的时间序列预测&#xff0c;输出训练集、测试集和预测数据结果&#xff0c;数据可更换自己的&#xff0c;程序已调通&#xff0c;可直接运行。 107 时间序列预测模糊推理系统 (xiaohongshu.com)

管理类联考——数学——真题篇——按题型分类——充分性判断题——蒙猜A/B

老规矩&#xff0c;看目录&#xff0c;平均3-5题 文章目录 A/B2023真题&#xff08;2023-19&#xff09;-A-选项特点&#xff1a;两个等号&#xff1b;-判断需联立的难易&#xff1a;难&#xff0c;看着感觉需要联立&#xff0c;所以判断联立需要有理论支撑&#xff0c;不然还…

QT qAbs()、qRound()

1.qAbs qAbs:原型为 T qAbs(const T &value) 返回输入参数对应类型的绝对值&#xff0c;其中T为输入参数类型&#xff0c;也就是可以返回多种类型&#xff08;int,float,double型&#xff09; 代码示例&#xff1a; int d -1; float b -3.14; double c -4.36;int a_…

具有超低功耗性能的R7F102GAC3CSP、R7F102GAC2DSP、R7F102G6C3CSP RL78/G22微控制器 16-bit MCU

RL78/G22 简介&#xff1a; 除了具有低电流消耗&#xff08;CPU工作时&#xff1a;37.5μA/MHz&#xff1b;STOP时&#xff1a;200nA&#xff09;外&#xff0c;RL78/G22微控制器还配备了丰富的电容触摸通道。完备的16-48引脚封装和32KB-64KB闪存&#xff0c;扩充了新一代RL78…

PMP认证需要多少钱?

PMP认证费太贵&#xff1f;这些可以省下来&#xff01; 学习PMP认证到拿证的过程中一共有两个地方需要有费用支出&#xff0c;第一是PMP培训费用&#xff0c;第二就是PMP考试费用。 为什么一定要参加培训&#xff1f;这是PMI的考试条件中要求的&#xff0c;任何考生都需要有35学…

【C++】开源:ImGui图形用户界面库配置与使用

&#x1f60f;★,:.☆(&#xffe3;▽&#xffe3;)/$:.★ &#x1f60f; 这篇文章主要介绍ImGui图形用户界面库配置与使用。 无专精则不能成&#xff0c;无涉猎则不能通。——梁启超 欢迎来到我的博客&#xff0c;一起学习&#xff0c;共同进步。 喜欢的朋友可以关注一下&…

【递归 回溯】LeetCode-226. 翻转二叉树

226. 翻转二叉树。 给你一棵二叉树的根节点 root &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。 示例 1&#xff1a; 输入&#xff1a;root [4,2,7,1,3,6,9] 输出&#xff1a;[4,7,2,9,6,3,1]示例 2&#xff1a; 输入&#xff1a;root [2,1,3] 输出&#xf…

实战篇:一文讲清楚电商平台用户评价分析

01 明确问题 随着电商平台的成熟&#xff0c;如何提升用户体验、提高客户留存率也成为了电商平台关注的重点。而用户评价是最直观地能反应用户体验的指标。用户差评更是其中的重点&#xff0c;通过差评分析&#xff0c;可以寻找到平台目前存在的可能导致用户打出差评的因素&am…

机器学习——特征选择(一)

【说明】文章内容来自《机器学习——基于sklearn》&#xff0c;用于学习记录。若有争议联系删除。 1、简介 特征选择&#xff0c;又称变量选择、属性选择或变量子集选择&#xff0c;是选择相关特征子集用于模型构造的过程。简要地说&#xff0c;通过检测相关特征。摒弃冗余特征…

TransXNet实战:使用 TransXNet实现图像分类任务(二)

文章目录 训练部分导入项目使用的库设置随机因子设置全局参数图像预处理与增强读取数据设置Loss设置模型设置优化器和学习率调整策略设置混合精度&#xff0c;DP多卡&#xff0c;EMA定义训练和验证函数训练函数验证函数调用训练和验证方法 运行以及结果查看测试完整的代码 在上…

脉冲水表作用有哪些?

脉冲水表是一种新型的水表&#xff0c;它通过检测水流量并发送脉冲信号来计量用水量。与传统的机械水表相比&#xff0c;脉冲水表具有许多优势和作用。 首先&#xff0c;脉冲水表具有高精度和可靠性。传统的机械水表在长期使用过程中会因磨损而导致计量不准确&#xff0c;而脉冲…

【强化学习】Deep Q Learning

Deep Q Learning 在前两篇文章中&#xff0c;我们发现RL模型的目标是基于观察空间 (observations) 和最大化奖励和 (maximumize sum rewards) 的。 如果我们能够拟合出一个函数 (function) 来解决上述问题&#xff0c;那就可以避免存储一个 (在Double Q-Learning中甚至是两个…

Redis介绍与使用

1、Nosql 1.1 数据存储的发展 1.1.1 只使用Mysql 以前的网站访问量不大&#xff0c;单个数据库是完全够用的。 但是随着互联网的发展&#xff0c;就出现了很多的问题&#xff1a; 数据量太大&#xff0c;服务器放不下 访问量太大&#xff0c;服务器也承受不了 1.1.2 缓存…