当前位置: 首页 > news >正文

C++修炼:list模拟实现

        Hello大家好!很高兴我们又见面啦!给生活添点passion,开始今天的编程之路!

我的博客:<但凡.

我的专栏:《编程之路》、《数据结构与算法之美》、《题海拾贝》、《C++修炼之路》

欢迎点赞,关注!

目录

 

1、list的底层结构

2、list容器的构造

3、迭代器类的完善

4、list类的完善

        4.1、迭代器操作

        4.2、insert

4.3、erase

4.4、其他复用接口

4.5、初始化列表和拷贝构造

4.6、赋值运算符重载

4.7、析构函数

5、补充


 

1、list的底层结构

        list底层是双向带头循环链表,这意味着我们可以高效的在list中插入,删除节点。但是不支持随机访问。如果我们想要获取特定位置的元素需要遍历链表。

2、list容器的构造

        list的模拟实现我们需要三个类,第一个类是节点,我们先把节点类写出来:

namespace danfan
{template<class T>struct list_node{list_node* _next;list_node* _prev;T _data;//构造函数list_node(const T& val = T()):_next(nullptr),_prev(nullptr),_data(val){}};
}

        其中next指向后一个节点的地址,prev指向前一个节点的地址,data是这个节点存放的数据:

        我们再大致写一下迭代器类:

template<class T,class ref,class ptr>
struct list_iterator
{typedef list_iterator<T,ref,ptr> iterator;typedef list_node<T> Node;Node* _node;//迭代器指向的节点的地址list_iterator(Node* node):_node(node){}
};

        我们这里其实需要三个模板变量,至于为什么需要三个我后面会说。

        我们发现其实迭代器类和节点类都是用struct封装的,原因就在于我们实际在访问的时候不回去访问这个底层的节点,那就没必要把他设置成私有变量,那就用不到struct,用class就足够了。

        接着我们再来写一下list类:

template<class T>
class list
{typedef list_node<T> Node;typedef list_iterator<T,T&,T*> iterator;typedef list_iterator<T, const T&, const T*> const_iterator;void empty_list(const T& val=T())
{_head = new Node;//别忘了开空间_head->_next = _head;_head->_prev = _head;_head->_data = val;//默认为0_size = 0;
}list(){empty_list();}
private:Node* _head;size_t _size;
};

         _size的用途就是可以返回链表的大小。

3、迭代器类的完善

        我们回过头来完善一下迭代器类 

	template<class T,class ref,class ptr>struct list_iterator{typedef list_iterator<T,ref,ptr> iterator;typedef list_node<T> Node;Node* _node;//迭代器指向的节点的地址list_iterator(Node* node):_node(node){}iterator operator++(){_node = _node->_next;return _node;}iterator operator++(int){iterator tmp(this->_node);_node = _node->_next;return tmp;}iterator operator--(){_node = _node->_prev;return _node;}iterator operator--(int){iterator tmp(this->_node);_node = _node->_prev;return tmp;}ref operator*(){return _node->_data;}ptr operator->(){return &_node->_data;}bool operator!=(const iterator& s) const{return _node != s._node;}bool operator==(const iterator& s) const{return _node == s._node;}};

        我们需要把对于迭代器的操作,主要是加减,等于,不等于,解引用,->写出来。我们注意到我们的比较操作符没有大于和小于,因为我们在一开始就说过了,list的迭代器在内存上没有地址的大小关系,所以说不能用大于和小于号来比较。另外迭代器加减,不等于,解引用这三个是必须提供的,只有这三个提供了才能使用范围for。

        另外写注释的是我们的->运算符重载,这个运算符重载其实是在特定场景使用的。他主要是在list存储自定义类的时候使用。比如我们可以这样访问:

struct A
{int _a;int _b;A(int a, int b):_a(a),_b(b){}
};
list<A> li;
auto it = li.begin();
cout << it->_a << endl;

        假设我们的begin()接口已经实现完了,那么我们就可以通过->符号访问元素。这里按道理来说应该是->->两个符号才能访问-a,但是由于可读性的问题,省略了一个->符号,所以只剩下一个 -> 也可以正常访问。这个地方属于是特殊处理

        因为咱们的迭代器有const和非const两个版本,所以我们直接在模板迭代器类传入三个模板参数,其中第二个参数和第三个参数是T&,T*或const T&,const T*。这样我们在list类中可以根据我们typedef的迭代器类型来让编译器自己决定返回迭代器的类型。

4、list类的完善

        4.1、迭代器操作

iterator begin()
{return _head->_next;
}
iterator end()
{return _head;
}
const_iterator begin() const
{return _head->_next;
}
const_iterator end() const
{return _head;
}

        4.2、insert

        我们先实现insert因为后面的push_back可以复用insert,之后有很多接口又复用的push_back。list的insert实际上是在提供的迭代器位置之前插入元素。

        push_back我就一起在这里实现了。

void insert(iterator pos,const T& val)
{Node* cur= pos._node;Node* prev = cur->_prev;Node* newnode = new Node(val);newnode->_next = cur;cur->_prev = newnode;prev->_next = newnode;newnode->_prev = prev;++_size;//别忘了
}
void push_back(const T& x)
{insert(end(), x);
}

4.3、erase

iterator erase(iterator pos)
{assert(pos != end());//pos不能是最后一个元素Node* cur = pos._node;Node* next = cur->_next;Node* prev = cur->_prev;prev->_next = next;next->_prev = prev;delete cur;--_size;return next;
}

        注意点很多我们从上往下说:

        首先我们一定得断言一下,但需要注意断言不能写成pos<end(),因为咱们在list里面的迭代器根本不支持大于小于比较

        其次,不要忘记delete,不然会内存泄漏

        第三点,我们一定得返回迭代器,因为删除之后会有迭代器失效的问题,原来的那个迭代器位置的节点我们已经删除了。我们返回next会调用赋值拷贝一个迭代器。这个赋值拷贝是必须存在的,因为如果穿引用返回的话我们的next出函数时候生命周期就结束了。

4.4、其他复用接口

void push_front(const T& x)
{insert(begin(), x);
}
void pop_back()
{erase(--end());
}
void pop_front()
{erase(begin());
}
size_t size()
{return _size;
}

4.5、初始化列表和拷贝构造

        实际上我们应该先实现拷贝构造才能进行以上我们实现的这些接口。

list(list<T>& li)
{empty_list();for (auto& e : li){push_back(e);}
}
list(std::initializer_list<T> il)
{empty_list();for (auto& e : il){push_back(e);}
}

4.6、赋值运算符重载

         这里还是采用复用swap的写法。

void swap(list<T> li)
{std::swap(_head,li._head);std::swap(_size,li._size);
}
list<T>& operator=(list<T> li)
{swap(li);return *this;
}

4.7、析构函数

void clear()
{iterator it1 = begin();for (it1 != end()){it1=erase(it1);//防止迭代器失效}
}
~list()
{clear();delete _head;_head = nullptr;_size = 0;
}

5、补充

         我们实际上只实现了几个常用的接口,那些不常用的我们并没有实现。

        我们现在补充一下关于迭代器的知识点: 

        迭代器分为以上几种,我们在调用各种接口的时候实际上是按照要求传入迭代器的。

        随机访问迭代器支持读取,写入,递增递减,随机访问,多次遍历。比如我们vector的迭代器就是随机访问迭代器。

        双向迭代器不支持随机访问,我们不能直接跳转到指定位置,只能通过遍历找到指定位置。list迭代器就是双向迭代器。

        前向迭代器在和双向迭代器相比又不支持递减操作。单链表,还有之后的哈希表就是前向迭代器。

        剩下的两个迭代器就是只读和只写迭代器。

        这五个迭代器都具有父子集关系,如果一个接口要求传入前向迭代器,那么传入他的父集双向迭代器和随机访问迭代器也可以。但是反过来如果一个接口要求传入随机访问迭代器,就只能传入随机访问迭代器,传入他的子集(也就是剩下那四个迭代器)是不行的。(比如sort)。

        如果要求传入只读和只写就是传剩下三个迭代器都可以。只读和只写迭代器没有具体的例子。

        好了,今天的内容就分享到这,我们下期再见!

  

 

 

相关文章:

C++修炼:list模拟实现

Hello大家好&#xff01;很高兴我们又见面啦&#xff01;给生活添点passion&#xff0c;开始今天的编程之路&#xff01; 我的博客&#xff1a;<但凡. 我的专栏&#xff1a;《编程之路》、《数据结构与算法之美》、《题海拾贝》、《C修炼之路》 欢迎点赞&#xff0c;关注&am…...

Lua 第12部分 日期和时间

Lua 语言的标准库提供了两个用于操作日期和时间的函数&#xff0c;这两个函数在 C 语言标准库中也存在&#xff0c;提供的是同样的功能。 虽然这两个函数看上去很简单&#xff0c;但依旧可以基于这些简单的功能完成很多复杂的工作。 Lua 语言针对日期和时间使用两种表示方式。 …...

NL2SQL调研

一 背景 1.1 引言 随着数据时代的到来&#xff0c;数据库已成为企业和组织存储、管理和分析数据的核心基础设施。然而&#xff0c;传统的数据库查询需要使用结构化查询语言&#xff08;SQL&#xff09;&#xff0c;这要求用户具备特定的技术知识&#xff0c;限制了数据库的广…...

服务器ubuntu镜像磁盘空间怎么管理

在 Ubuntu 服务器上&#xff0c;管理镜像磁盘空间是系统维护中的一项关键任务&#xff0c;尤其是在使用虚拟化技术时(如 Docker、LVM、KVM 等)。合理管理磁盘空间可以有效防止磁盘空间不足&#xff0c;提升系统的稳定性和性能。本文将为你介绍如何在 Ubuntu 系统中有效管理镜像…...

uniapp+vue3表格样式

<view class"tableMain" v-if"state.use_scope2"><view class"tableBox"><view class"th"><view class"col">站点名称</view><view class"col">站点状态</view><vi…...

QT中的文件操作

C语言中通过fopen/fread/fwrite/fclose进行文件操作 C中通过fstream/>>/<</close进行文件操作 Linux中通过open/read/write/clos进行文件操作 Qt中同样可以使用上述文件操作 但是Qt同样封装了自己的一套文件操作&#xff0c;&#xff0c;在编写Qt程序时&#xf…...

Vue.js 核心特性解析:响应式原理与组合式API实践

引言 Vue.js 作为一款渐进式前端框架&#xff0c;凭借其简洁的API设计和灵活的组件化开发模式&#xff0c;已经成为现代Web开发的主流选择之一。本文将深入探讨Vue 3的核心特性&#xff0c;包括响应式系统原理、组合式API的使用以及实际开发中的最佳实践&#xff0c;帮助开发者…...

李沐动手深度学习(pycharm中运行笔记)——07.自动求导

07.自动求导&#xff08;与课程对应&#xff09; 1、导入torch import torch 2、假设我们想对函数 y 2x.Tx&#xff0c;就是 2乘x的内积&#xff0c;关于列向量x求导&#xff0c;也就是4x x torch.arange(4.0) # &#xff08;1&#xff09;创建一个列向量 x print("…...

Maven 使用教程

Maven 使用教程 Maven 是一个强大的项目管理和构建工具&#xff0c;主要用于 Java 项目的开发。它通过定义良好的生命周期、插件系统和依赖管理简化了项目的构建过程。本文将详细介绍如何使用 Maven 来进行日常的开发工作。 安装 Maven 下载 Maven 访问 Maven 的官方网站&a…...

ACM会议模板设置单排作者数量

在准备ACM会议的ready版本时涉及到作者设置&#xff0c;ACM会议模板的默认设置是每排三个作者&#xff0c;但是修改为四个一般是可以允许的&#xff0c;可能会节省一些空间。只需要在\documentclass[sigconf,authordraft]{acmart}后面添加代码\settopmatter{authorsperrow4}&am…...

云原生 | K8S中数据存储之StorageClass

在一个大规模的Kubernetes集群里,可能有成千上万个PVC,这就意味着运维人员必须实现创建出这个多个 PV,此外,随着项目的需要,会有新的PVC不断被提交,那么运维人员就需要不断的添加新的,满足要求的PV,否 则新的Pod就会因为PVC绑定不到PV而导致创建失败。而且通过 PVC 请求到一定的…...

衡量矩阵数值稳定性的关键指标:矩阵的条件数

文章目录 1. 定义2. 为什么要定义条件数&#xff1f;2.1 分析线性系统 A ( x Δ x ) b Δ b A(x \Delta x) b \Delta b A(xΔx)bΔb2.2 分析线性系统 ( A Δ A ) ( x Δ x ) b (A \Delta A)(x \Delta x) b (AΔA)(xΔx)b2.3 定义矩阵的条件数 3. 性质及几何意义3…...

蓝桥杯 1. 确定字符串是否包含唯一字符

确定字符串是否包含唯一字符 原题目链接 题目描述 实现一个算法来识别一个字符串的字符是否是唯一的&#xff08;忽略字母大小写&#xff09;。 若唯一&#xff0c;则输出 YES&#xff0c;否则输出 NO。 输入描述 输入一行字符串&#xff0c;长度不超过 100。 输出描述 输…...

【Vue】单元测试(Jest/Vue Test Utils)

个人主页&#xff1a;Guiat 归属专栏&#xff1a;Vue 文章目录 1. Vue 单元测试简介1.1 为什么需要单元测试1.2 测试工具介绍 2. 环境搭建2.1 安装依赖2.2 配置 Jest 3. 编写第一个测试3.1 组件示例3.2 编写测试用例3.3 运行测试 4. Vue Test Utils 核心 API4.1 挂载组件4.2 常…...

查回来的数据除了 id,其他字段都是 null

数据结构不完整&#xff1a;您收到的历史对话和知识库文件数据中&#xff0c;几乎所有重要的字段&#xff08;除了id和title&#xff09;都是null&#xff0c;包括userId、createdTime等关键字段。这会导致前端无法根据创建时间来正确分类显示&#xff08;今天、7天内、更早&am…...

Flink02-学习-套接字分词

flatmap() AMapFunction仅适用于执行一对一转换的情况&#xff1a;对于每个进入的流元素&#xff0c;map()都会发出一个转换后的元素。否则&#xff0c;您需要使用 flatmap() DataStream<TaxiRide> rides env.addSource(new TaxiRideSource(...));DataStream<Enric…...

html5:从零构建经典游戏-扫雷游戏

扫雷是Windows系统自带的经典游戏&#xff0c;陪伴了许多人的童年。 本文将详细解析一个用HTML、CSS和JavaScript实现的扫雷游戏代码&#xff0c;带你了解其背后的实现原理。 游戏概述 这个扫雷游戏实现包含以下核心功能&#xff1a; 1010的游戏棋盘 15个随机分布的地雷 左…...

SVT-AV1源码分析-函数svt_aom_motion_estimation_kernel

一 svt_aom_motion_estimation_kernel函数作用 这段代码是EBSDK 中的一个运动估计 内核函数&#xff0c;用于处理视频编码中的运动估计任务。运动估计任务。运动估计是视频编码中的一个关键步骤&#xff0c;目的是在时间域上找到当前块在参考帧中的最佳匹配块&#xff0c;从而减…...

考研系列-计算机组成原理第六章、总线

一、总线概述 1.总线的基本概念 2.总线的分类 (1)按照传输格式 并行总线的传输速度并不一定比串行总线快,因为并行总线之间存在干扰,不能太快。 (2)按照总线功能 片内总线、系统总线、IO总线、通信总线...

HTML基础完全解析

一、HTML基本结构解析 1.1 文档骨架 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><title>文档标题</title> </head> <body>页面主体内容 </body> </html> &#x1f3…...

【读写视频】MATLAB详细代码

MATLAB将视频逐帧输出 在MATLAB中&#xff0c;可以使用VideoReader和imwrite函数将视频逐帧输出为图像文件。以下是具体步骤和示例代码&#xff1a; 读取视频并逐帧保存为图像 首先&#xff0c;使用VideoReader函数读取视频文件&#xff0c;然后使用read函数逐帧读取视频&am…...

NCCL 通信与调试

代码仓库 https://github.com/NVIDIA/nccl-tests 代码编译 编译 nccl-tests (MPI 版本): ” 编译支持 MPI 的 nccl-tests 是整合 nvcc, mpicc 和 NCCL 库的关键步骤 初始编译命令 (基于 README): cd /path/to/your/nccl-tests # 进入源码目录 make clean make MPI1 CUDA_HO…...

Linux 在个人家目录下添加环境变量 如FLINK_PROPERTIES=“jobmanager.rpc.address: jobmanager“

问题&#xff1a; Docker Flink Application Mode 命令行形式部署前&#xff0c;需要在Linux执行以下&#xff1a; $ FLINK_PROPERTIES"jobmanager.rpc.address: jobmanager" $ docker network create flink-network 临时变量只在当前session会话窗口生效&#xf…...

Linux中线程池的简单实现 -- 线程安全的日志模块,策略模式,线程池的封装设计,单例模式,饿汉式单例模式,懒汉式单例模式

目录 1. 对线程池的理解 1.1 基本概念 1.2 工作原理 1.3 线程池的优点 2. 日志与策略模式 2.1 日志认识 2.2 策略模式 2.2.1 策略模式的概念 2.2.2 工作原理 2.2 自定义日志系统的实现 3. 线程池设计 3.1 简单线程池的设计 3.2 线程安全的单例模式线程池的设计 3…...

【Web API系列】深入解析 Web Service Worker 中的 WindowClient 接口:原理、实践与进阶应用

前言 在现代 Web 开发领域中&#xff0c;Service Worker 技术已成为构建离线优先应用和实现高级缓存策略的核心支柱。作为 Service Worker API 体系中的重要组成部分&#xff0c;WindowClient 接口为开发者提供了对受控客户端窗口的精准控制能力。本文将从实际工程实践的角度出…...

哈希封装unordered_map和unordered_set的模拟实现

文章目录 &#xff08;一&#xff09;认识unordered_map和unordered_set&#xff08;二&#xff09;模拟实现unordered_map和unordered_set2.1 实现出复用哈希表的框架2.2 迭代器iterator的实现思路分析2.3 unordered_map支持[] &#xff08;三&#xff09;结束语 &#xff08;…...

智诚科技苏州SOLIDWORKS授权代理商的卓越之选

在当今数字化转型浪潮中&#xff0c;SOLIDWORKS软件以其强大的功能和广泛的行业应用&#xff0c;成为企业迈向智能制造的有力工具。它不仅提供直观的3D建模环境&#xff0c;帮助企业设计师快速创建精准的3D模型&#xff0c;还涵盖了从概念设计到详细设计、从样品制作到最终产品…...

【网络原理】从零开始深入理解TCP的各项特性和机制.(二)

本篇博客给大家带来的是TCP/IP原理的知识点,重点以TCP为主,接续上篇. &#x1f40e;文章专栏: JavaEE初阶 &#x1f680;若有问题 评论区见 ❤ 欢迎大家点赞 评论 收藏 分享 如果你不知道分享给谁,那就分享给薯条. 你们的支持是我不断创作的动力 . 王子,公主请阅&#x1f680; …...

51单片机所有寄存器介绍

51单片机所有寄存器介绍 作者将狼才鲸创建日期2025-04-27 参考资料&#xff1a;Intel官方《MCS-51 Programmer’s Guide and Instruction Set.pdf》CSDN阅读地址&#xff1a;51单片机所有寄存器介绍 一、前言 51单片机的寄存器和ARM不一样&#xff0c;有自己专有的名称&…...

4.27算法题

力扣649.Dota2 参议院 649. Dota2 参议院 Dota2 的世界里有两个阵营&#xff1a;Radiant&#xff08;天辉&#xff09;和 Dire&#xff08;夜魇&#xff09; Dota2 参议院由来自两派的参议员组成。现在参议院希望对一个 Dota2 游戏里的改变作出决定。他们以一个基于轮为过程…...

衡石科技:HENGSHI SENSE 数据权限解决方案

编写目的​ 本方案主要讲述 HENGSHI SENSE 的数据权限方案&#xff0c;即在 HENGSHI SENSE 系统中&#xff0c;通过同步企业内部的人员属性和组织架构等信息&#xff0c;实现企业内部的每一个用户对于业务数据的读取权限。 本方案的的预期读者为&#xff1a;HENGSHI SENSE 的…...

矩阵系统源码搭建热门音乐功能板块开发,支持OEM

在数字音乐蓬勃发展的当下&#xff0c;矩阵系统中的热门音乐功能板块成为吸引用户的重要部分。它不仅能为用户推荐当下流行的音乐&#xff0c;还能提升用户在系统中的活跃度和留存率。本文将通过详细的源码搭建过程&#xff0c;带你了解如何在矩阵系统中实现一个功能完备的热门…...

深入理解Android Activity生命周期

引言 在Android开发中,理解Activity的生命周期对于创建高效、稳定的应用程序至关重要。无论你是初学者还是资深开发者,掌握Activity生命周期的概念都能帮助你更好地管理资源、优化性能以及处理各种用户交互场景。本文将详细介绍Activity生命周期中的各个事件,并通过示例代码…...

【WEB3】web3.0是什么

互联网在不断发展。 我们即将翻开新的篇章&#xff0c;迎来翻天覆地的变化。 — Web 1.0 只能阅读信息。 它主要是供我们访问和阅读信息&#xff0c;只有极少数人可以真正发布内容。 — Web 2.0&#xff0c;即互联网目前所处的阶段&#xff0c;我们能够在网络上发布内容、建立…...

2025上海车展 | 移远通信重磅发布AR脚踢毫米波雷达,重新定义“无接触交互”尾门

4月25日&#xff0c;在2025上海国际汽车工业展览会期间&#xff0c;全球领先的物联网和车联网整体解决方案供应商移远通信宣布&#xff0c;其全新AR脚踢毫米波雷达RD7702AC正式发布。 该产品专为汽车尾门“无接触交互”设计&#xff0c;基于先进的毫米波技术&#xff0c;融合AR…...

ubuntu安装git及使用(本地git)

ubuntu安装git及使用教程&#xff08;本地git&#xff09; 1.ubuntu安装git1.1 查看自己的Ubuntu是否已经装有git1.2 下面进行介绍如何Ubuntu终端安装git &#xff08;若已安装则可忽略&#xff09; 2. 配置Git基本信息2.1 若不清楚是否配置的可使用如下命令查看2.2 未配置用户…...

数智读书笔记系列031《HIS内核设计之道——医院信息系统规划设计系统思维》书籍简介与读书笔记

一、作者与出版信息 作者团队(核心贡献者) 任连仲 身份:中国工程院院士(2022年当选),解放军总医院信息科原主任技术贡献: 主导“军字一号”系统架构设计(1997-2005年),支撑全国300余家三甲医院信息化建设提出“医疗数据语义网格”理论,获国家科技进步二等奖(2018年…...

WinForm真入门(18)——DateTimePicker‌控件解析

一、基本概念‌ ‌DateTimePicker‌ 是 Windows 窗体中用于选择日期和时间的控件&#xff0c;支持以下交互方式&#xff1a; 通过下拉日历选择日期通过上下按钮调整时间直接输入日期或时间 适用于需要规范日期格式、限制日期范围或快速输入的场景&#xff08;如预约系统、数据…...

关于堆栈指针的那些事 | bootloader 如何跳转app

问题描述 堆栈指针的值通常存储在 App 的向量表&#xff08;Vector Table&#xff09;的第一个位置&#xff08;0x08002000&#xff09;&#xff0c;为什么&#xff1f; 在嵌入式系统中&#xff0c;堆栈指针&#xff08;SP&#xff09;的值存储在应用程序&#xff08;App&…...

如何在 iPhone 上恢复已删除的联系人:简短指南

从 iPhone 中删除联系人相当容易&#xff0c;但如果您不小心删除了错误的联系人或丢失了所有联系人怎么办&#xff1f;这可能是任何智能手机用户都可能发生的最糟糕的噩梦之一。 如何在 iPhone 上恢复已删除的联系人 我个人在我的列表上看到几个用户发布关于他们如何丢失所有联…...

使用Aspose.Words将Word转换为HTML时,字体样式丢失问题及解决方法

使用Aspose.Words将Word转换为HTML时&#xff0c;字体样式丢失问题及解决方法 引言 ✨一、问题描述 &#x1f4c9;二、问题分析 &#x1f50d;三、解决方案 &#x1f6e0;️四、总结 &#x1f3c1; 引言 ✨ 在实际开发中&#xff0c;使用Aspose.Words将Word文档转换为HTML格式…...

更快的图像局部修改与可控生成:Flex.2-preview

Flex.2-preview 文本生成图像扩散模型介绍 一、模型简介 Flex.2-preview 是一种 开源的 80 亿参数文本生成图像扩散模型&#xff0c;具备通用控制和修复支持功能&#xff0c;是 Flex.1alpha 的下一代版本。该模型由社区开发并为社区服务&#xff0c;采用 Apache 2.0 许可证&a…...

汽车制造行业如何在数字化转型中抓住机遇?

近年来&#xff0c;随着新一轮科技革命和产业变革的深入推进&#xff0c;汽车制造行业正迎来一场前所未有的数字化转型浪潮。无论是传统车企还是新势力品牌&#xff0c;都在积极探索如何通过数字化技术提升竞争力、开拓新市场。那么&#xff0c;在这场变革中&#xff0c;汽车制…...

数据可视化 —— 直方图

一、前言 直方图&#xff08;Histogram&#xff09;是一种用柱状图形表示数据分布的统计图表&#xff0c;它将数据划分为连续的区间&#xff08;称为“分箱”或“区间”&#xff09;&#xff0c;统计每个区间内的数据频数&#xff08;或频率&#xff09;&#xff0c;并用柱形的…...

1、Linux操作系统下,ubuntu22.04版本切换中英文界面

切换中英文界面的方法很多&#xff0c;我也是按照一个能用的方法弄过来并且记录&#xff0c; 1.如果刚开始使用Ubuntu环境&#xff0c;桌面的语言环境为英文&#xff0c;需要安装中文简体的字体包 打开桌面终端&#xff0c;输入 sudo apt install language-pack-zh-hans lan…...

《MySQL 技术内幕-innoDB 存储引擎》笔记

&#x1f4a1; 根据 遗忘曲线&#xff1a;如果没有记录和回顾&#xff0c;6天后便会忘记75%的内容 读书笔记正是帮助你记录和回顾的工具&#xff0c;不必拘泥于形式&#xff0c;其核心是&#xff1a;记录、翻看、思考::: 书名MySQL 技术内幕-innoDB 存储引擎作者姜承尧状态已读…...

C++ AVL树的实现

在上一篇博客我们学习了二叉搜索树的实现&#xff0c;现在我们开始手动实现AVL树。 二叉搜索树-CSDN博客 1.AVL树的概念 AVL树是最先发明的⾃平衡⼆叉查找树&#xff0c;AVL是⼀颗空树&#xff0c;或者具备下列性质的⼆叉搜索树&#xff1a;它的左右⼦树都是AVL树&#xff0c…...

多视觉编码器协同与高低分辨率特征融合技术综述

本文主要介绍&#xff08;论文发表时间&#xff1a;24.03-25.01&#xff09;在多模态中使用多个视觉编码器如何进行特征融合操作&#xff08;之所以用多视觉编码器&#xff0c;主要用途在于&#xff1a;有些视觉编码器可能只能提取到部分信息&#xff0c;就想通过另外一个编码器…...

力扣4-最长公共前缀

一.题目 编写一个函数来查找字符串数组中的最长公共前缀。 如果不存在公共前缀&#xff0c;返回空字符串 ""。 示例 1&#xff1a; 输入&#xff1a;strs ["flower","flow","flight"] 输出&#xff1a;"fl"示例 2&…...

贪心算法-860.柠檬水找零-力扣(LeetCode)

一、题目解析 我们需要注意我们是没有初始零钱的&#xff0c;所以当第一个顾客支付10或20时&#xff0c;无法找零此时返回false。 二、算法解析 根据贪心算法的解决方式&#xff0c;我们需要先把解决该问题分解为若干步。 首先对于顾客支付的钱共有三种&#xff0c;5&#xf…...