从二叉树到 STL:揭开 set 容器的本质与用法

从二叉树到 STL:揭开 set 容器的本质与用法

前言:

        上次介绍完二叉搜索树后,更新中断了一段时间,先向大家致歉。最近学习状态有些起伏,但我正在努力调整,相信很快会恢复节奏。今天我们继续深入探讨——关联容器,它在算法和工程中都非常常见和重要。

1.之前的遗漏

        我之前写的二叉搜索树其实没有写完,我仅仅写了一个节点只能存储一个值的二叉搜索树。在我们日常的工作中,这种树的使用率其实还是比较低的。最受欢迎的是里面存储两个值的二叉搜索树,这个可以类比Python中的字典。相信学过python的读者对此不陌生,字典其实存放了一对值,分别是Key和Value,类比英文字典中的英语和汉字,我们通过英文(Key)来找到对应的中文(Value)。这其实才是我们常使用到的二叉搜索树,下面我通过举例来帮助各位理解这两棵树的区别。

1.1.Key搜索场景

        举个例子,现在很多小区配有地下停车库。业主的车牌号会录入系统中,车辆进入时由系统识别并判断是否允许进入。这就是典型的 Key 搜索场景 —— 只需根据一个关键字(车牌号)进行查找。

1.2.Key/Value搜索场景

        还是以我们的生活举例,如今我们进入各大商场的时候,如果开车的话难免会需要停进商场专用的停车场,此时这就是停车场计费系统,我们需要录入两个值:车子的车牌号以及入场时间,记录好之后,当车辆想要离开停车场的时候,就会通过车牌(Key)来进行系统中管理的车辆信息进行检索,检索成功后会根据当前的时间减去入场的时间计算出车辆在停车场呆过的时间,从而计算出需要交付的金额。这边是Key/Value的搜索场景,Key其实不是关键,其中的Value才是关键,Key更像是一个标识符,我们通过这个符号来进行真正数据的获取。所以可以看出,它在我们日常的生活中使用的频率更大。

1.3.Key/Value类型的二叉搜索树的源码

        由于难度不大,小编就不讲其中的细节了,其实它和上篇我们讲述的Key类型的二叉搜索数一样,只不过多了一个Value而已。

#include<iostream> #include<vector> ​ using namespace std; template<class K, class V> struct BSTNode { // pair<K, V> _kv; K _key; V _value; BSTNode<K, V>* _left; BSTNode<K, V>* _right; BSTNode(const K& key, const V& value)       :_key(key)       , _value(value)       , _left(nullptr)       , _right(nullptr)   {} }; template<class K, class V> class BSTree {    typedef BSTNode<K, V> Node; public:    BSTree() = default;    BSTree(const BSTree<K, V>& t)   {        _root = Copy(t._root);   }    BSTree<K, V>& operator=(BSTree<K, V> t)   {        swap(_root, t._root);        return *this;   }    ~BSTree()   {        Destroy(_root);        _root = nullptr;   }    bool Insert(const K& key, const V& value)   {        if (_root == nullptr)       {            _root = new Node(key, value);            return true;       }        Node* parent = nullptr;        Node* cur = _root;        while (cur)       {            if (cur->_key < key)           {                parent = cur;                cur = cur->_right;           }            else if (cur->_key > key)           {                parent = cur;                cur = cur->_left;           }            else           {                return false;           }       }        cur = new Node(key, value);        if (parent->_key < key)       {            parent->_right = cur;       }        else       {            parent->_left = cur;       }        return true;   }    Node* Find(const K& key)   {        Node* cur = _root;        while (cur)       {            if (cur->_key < key)           {                cur = cur->_right;           }            else if (cur->_key > key)           {                cur = cur->_left;           }            else           {                return cur;           }       }        return nullptr;   }    bool Erase(const K& key)   {        Node* parent = nullptr;        

Read more

Python数学可视化——显函数、隐函数及复杂曲线的交互式绘图技术

Python数学可视化——显函数、隐函数及复杂曲线的交互式绘图技术

Python数学可视化——显函数、隐函数及复杂曲线的交互式绘图技术 一、引言 在科学计算和数据分析中,函数与方程的可视化是理解数学关系和物理现象的重要工具。本文基于Python的Tkinter和Matplotlib库,实现一个功能完善的函数与方程可视化工具,支持显函数、隐函数、特殊曲线(如心形线)及物理场分布(如电势)的交互式绘图,并提供安全的表达式解析、图像保存等功能。 二、核心技术架构 2.1 系统架构与技术选型 * 界面层:使用Tkinter构建GUI,包含类型选择、表达式输入、预设函数下拉菜单等控件 * 计算层: * 显函数:通过np.linspace生成采样点,安全计算函数值 * 隐函数:基于等高线算法contour绘制等值线 * 安全机制:通过正则表达式过滤非法字符,限制白名单函数防止代码注入 * 可视化层:Matplotlib实现图表渲染,支持动态更新和交互式工具条 2.2 安全表达式解析 defis_valid_expression(expr):""

By Ne0inhk
《C++进阶之STL》【unordered_set/unordered_map 使用介绍】

《C++进阶之STL》【unordered_set/unordered_map 使用介绍】

【unordered_set/unordered_map 使用介绍】目录 * 前言 * ------------unordered_set------------ * 一、介绍 * 二、接口 * 1. 常见的构造 * 2. 容量的操作 * std::unordered_set::size * std::unordered_set::empty * 3. 访问的操作 * std::unordered_set::find * std::unordered_set::count * 4. 修改的操作 * std::unordered_set::clear * std::unordered_set::swap * std::unordered_set::insert * std:

By Ne0inhk
Python 驱动浏览器自动化:Playwright + AI 的 2026 最佳实践

Python 驱动浏览器自动化:Playwright + AI 的 2026 最佳实践

摘要:在 Web 自动化领域,Selenium 曾经的霸主地位已成历史,Playwright 凭其“快、稳、强”的现代特性成为了新标准。而在 2026 年,随着 LLM(大语言模型)和视觉多模态模型的爆发,自动化测试与 RPA(机器人流程自动化)迎来了范式革命。本文将深度解析 Playwright 的核心架构,并手把手教你构建一个具备“自愈能力”的 AI 驱动自动化 Agent。本文超 7000 字,包含大量实战代码与反爬对抗技巧。 第一章:Selenium 已死,Playwright 当立? 1.1 自动化的“不可能三角” 长期以来,Web 自动化工程师都在速度、稳定性和抗检测性之间做取舍: * Selenium:

By Ne0inhk
蓝香蕉代码 |【鸿蒙电脑开发编译C/C++】

蓝香蕉代码 |【鸿蒙电脑开发编译C/C++】

lycium_plusplus介绍 项目地址 lycium++支持鸿蒙电脑使用 上次我们介绍了lycium++框架的扩展,最近针对在鸿蒙电脑上使用框架也进行下介绍 如何使用 解决了什么问题 lycium++框架支持在win/mac/linux上进行交叉编译,支持一件打包hnp文件,通过这些hnp作为组件与应用一起安装到鸿蒙电脑上,在HarmonyOS上使用该框架也成为了可能。本次我们将框架在鸿蒙电脑上进行了适配,通过交叉编译解决了在鸿蒙电脑上执行编译的工具最小集,并伴随DevBox、Python安装器、DevNode-OH、GitNext几个核心应用的上架,解决了在鸿蒙电脑中,通过命令行编译C/C++代码的核心问题。 环境介绍 * 设备:我使用的MateBook Pro已经升级到6.0.0.115版本,建议升级到该版本以上 * 代码管理工具:GitNext,作为代码管理工具下载管理三方库等,下载后可在系统终端中使用(个人推荐),也可以使用界面管理 * 编译工具链:DevBox,包含了llvm、clang、autoconf、bash、cmake、make、nin

By Ne0inhk