数据结构——链表——模板类实现双向链表——先完成再完美——持续更

链表:概念,实现,《数据结构》这里实现是基于模板的

C++语言基础,指针,引用。模板。《C++Primer》有些进阶用法放在语言学习的目录

LeetCode应用,会更新在LeetCode150,目前这个系列先暂停,数据结构更新一期,再更对应的题目解题。

新手村入门,可以根据下面实现的过程中,忘记的知识点,再回头看。

新手村入门

链表概念

列表:逻辑上有序,物理上无序(动态存储策略)【与向量一样,列表也是由具有线性逻辑次序的一组元素的集合。链表结构一般化推广】

好处:降低动态操作成本(插入,删除)O(1)

劣势:静态操作(查找,需要扫描一遍列表元素)O(n)

 L = \left \{ a_{0}, a_{1},..., a_{n-1} \right \}

元素称为节点;

模板函数的创建与模板类的创建

C++中的模板是一种允许我们为类或者函数定义一种通用模式的机制,这种通用模式可以用于创建多种数据类型的类或函数实例,而无需为每个类型都编写单独的代码。模板有两种主要类型:函数模板和类模板。

函数模板入门

函数模板允许我们定义一个通用的函数,该函数可以接受多种数据类型的参数。模板参数列表在函数定义之前用尖括号<>括起来,并紧跟在template关键字之后。

下面是一个简单的函数模板示例,它用于交换两个值的位置:

template <typename T> // 模板参数列表,typename T 是一个类型模板参数  
void swap(T& a, T& b) {  
    T temp = a;  
    a = b;  
    b = temp;  
}

在这个例子中,T是一个类型模板参数,它在编译时会被实际类型(如intdoublestd::string等)替换。

类模板

类模板允许我们定义一个通用的类,该类可以用于多种数据类型。与函数模板类似,类模板的模板参数列表也位于类声明之前,并紧跟在template关键字之后。

下面是一个简单的类模板示例,它用于创建一个动态数组:

template <typename T> // 模板参数列表  
class Array {  
private:  
    T* data;  
    size_t size;  
  
public:  
    Array(size_t s) : size(s), data(new T[s]) {}  
    ~Array() { delete[] data; }  
  
    T& operator[](size_t index) {  
        return data[index];  
    }  
  
    // 其他成员函数...  
};

在这个例子中,T是一个类型模板参数,它决定了数组data中元素的类型。

模板参数列表

模板参数列表可以包含多个类型模板参数,也可以包含非类型模板参数(如整数常量或指针)。类型模板参数用typenameclass关键字声明(两者在模板参数声明中是等价的),而非类型模板参数可以是整数、指针或其他非类型值。

下面是一个包含多个类型模板参数的类模板示例:

template <typename Key, typename Value> // 包含两个类型模板参数  
class Map {  
    // ... 类的实现,可能包含以Key和Value为类型的成员 ...  
};

下面是一个包含非类型模板参数的函数模板示例:

template <typename T, size_t N> // 包含一个类型模板参数和一个非类型模板参数  
void printArray(const T (&array)[N]) {  
    for (size_t i = 0; i < N; ++i) {  
        std::cout << array[i] << ' ';  
    }  
    std::cout << std::endl;  
}

在这个例子中,T是一个类型模板参数,而N是一个非类型模板参数(一个size_t类型的常量)。

OOP封装

在面向对象编程(OOP)中,封装(Encapsulation)是一个核心概念,它指的是将对象的属性和方法(或称为成员变量和成员函数)隐藏在对象内部,只通过公共接口(通常是公有方法)与外部世界进行交互。封装有助于隐藏对象的内部细节,防止外部代码直接访问或修改对象的内部状态,从而确保对象的完整性和安全性。

未封装处理通常指的是在编程中没有使用封装的概念,对象的属性和方法都是公开的,可以直接被外部代码访问和修改。这种编程方式可能会导致代码的可读性、可维护性和安全性降低。

下面是一个简单的例子来说明封装处理和未封装处理的区别:

未封装处理(不推荐)
class Person {  
public:  
    int age; // 年龄是公开的  
  
    // 没有提供任何方法来修改年龄  
};  
  
int main() {  
    Person p;  
    p.age = -5; // 外部代码可以直接修改年龄,甚至设置为一个不合理的值  
    return 0;  
}

在这个例子中,Person 类的 age 属性是公开的,任何外部代码都可以直接访问和修改它。这可能导致问题,因为年龄不应该是一个负数。

封装处理(推荐)
class Person {  
private: // 使用私有访问修饰符来隐藏属性  
    int age;  
  
public:  
    // 提供公有方法来设置年龄  
    void setAge(int newAge) {  
        if (newAge >= 0) { // 添加一个检查来确保年龄是非负的  
            age = newAge;  
        } else {  
            std::cerr << "Age cannot be negative!" << std::endl;  
        }  
    }  
  
    // 提供公有方法来获取年龄  
    int getAge() const {  
        return age;  
    }  
};  
  
int main() {  
    Person p;  
    p.setAge(-5); // 尝试设置一个不合理的年龄  
    // 输出:Age cannot be negative!  
    // 由于设置了检查,年龄没有被修改为-5  
    std::cout << "Person's age: " << p.getAge() << std::endl; // 输出:Person's age: 0(或之前的值,如果之前有设置过)  
    return 0;  
}

在这个封装处理的例子中,Person 类的 age 属性是私有的,外部代码不能直接访问或修改它。相反,我们提供了两个公有方法 setAgegetAge 来分别设置和获取年龄。在 setAge 方法中,我们添加了一个检查来确保年龄是非负的。这样,即使外部代码尝试设置一个不合理的年龄,它也会被拒绝,从而确保了对象的完整性和安全性。

函数模板进阶用法和注意(另一篇总结中)

指针和引用的区别 (另一篇总结中)

《数据结构(C++语言版)》不懂的专业术语

秩,线性代数的一个概念,极大线性无关。。。还在上大学的别学我,我的线代还给老师了。

专业解释,百度或者书本,在下面的链表中,简单理解为表示一个位置,像数组下标,秩相同(下标相同)。

ADT 抽象数据类型,一般指数据的某种抽象和操作

API 应用程序结构,软件之间的交互

我们下面的目标是,根据书中提供的 ADT,代码模板,写出一个可以运行的模板链表类,Let's Go!

链表之旅

第一个任务,列表节点 

注意:默认链表中每个节点都有数据,并且未对数据进行封装处理。

第二个任务,列表的实现

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

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

相关文章

【PB案例学习笔记】-09滚动条使用

写在前面 这是PB案例学习笔记系列文章的第8篇&#xff0c;该系列文章适合具有一定PB基础的读者。 通过一个个由浅入深的编程实战案例学习&#xff0c;提高编程技巧&#xff0c;以保证小伙伴们能应付公司的各种开发需求。 文章中设计到的源码&#xff0c;小凡都上传到了gitee…

云界洞见——基于移动云云数据库MySQL应用实践

目录 简介1 新手入门1.1 创建MySQL实例1.2 公网连接MySQL实例 2 操作指南2.1 创建数据库2.2 数据备份设置2.3 日志管理2.4 监控告警2.5 代码审计 3 应用场景4 总结 如今&#xff0c;大型企业如金融企业和银行等&#xff0c;在下一代的微服务架构转型要求下&#xff0c;需要基础…

C++ prime 第五版 第14章 重载运算与类型转换

一、基本概念 重载的运算符是具有特殊名字的函数&#xff1a;它们的名字由关键字operator和其后要定义的运算符号共同组成。和其他函数一样&#xff0c;重载的运算符也包含返回类型、参数列表以及函数体。 我们不能为内置类型的运算对象重定义运算符。对于一个运算符函数来说&…

【Week-R1】RNN实现心脏病预测,基于tensorflow框架

文章目录 一、什么是RNN&#xff1f;二、准备环境和数据2.1 导入数据 三、构建模型四、训练和预测五、其他&#xff08;1&#xff09;sklearn模块导入报错&#xff1a;ModuleNotFoundError: No module named sklearn&#xff08;2&#xff09;优化器改为SGD&#xff0c;accurac…

MySQL--备份恢复

目录 一、备份恢复的工作职责 1.备份的时间周期 2.备份的方式 3.恢复方案 4.检查备份 5.定期恢复演练 6.故障恢复策略 7.迁移升级 二、逻辑备份工具--mysqldump 1.介绍 2.使用场景 3.mysqldump命令的参数介绍 1&#xff09;全备&#xff1a; 2&#xff09;单库或…

四轮麦轮平衡车四个轮子安放位置要求,以及编码器测速注意事项(强调,否则无法正常平移)——基于STM32F103ZET6

轮子推荐ABBA&#xff0c;当然BAAB也可以 如图安放&#xff1a; 这两种安防位置可以实现平移效果 若要实现平移则需要先实现PID控制平衡&#xff0c;这里用到520编码电机&#xff0c;相较于370电机他的动力更足&#xff0c;在调节PID时能节约不少时间而且更加容易。 需要注意…

基于离散小波变换(DWT)的心电信号伪影去除及心电信号PQRST波检测(MATLAB R2018)

心电信号是心脏神经&#xff0c;肌肉组织电化学活动的表现形式。这些电化学活动使心脏内部产生一系列非常协调的电刺激脉冲&#xff0c;分别使心房&#xff0c;心室的肌肉细胞兴奋&#xff0c;从而有节律的舒张和收缩。这些生物电活动在体表的不同部位形成不同的电位差变化&…

622.设计循环队列

typedef struct {int* a;int head;int tail;int k; } MyCircularQueue;bool myCircularQueueIsEmpty(MyCircularQueue* obj); bool myCircularQueueIsFull(MyCircularQueue* obj);//初始化 MyCircularQueue* myCircularQueueCreate(int k) {MyCircularQueue* obj(MyCircularQue…

ARM+FPGA+NVIDIA AI摄像头软硬件定制

拥有资深ISP图像技术团队&#xff0c;是英伟达、地平线等合作伙伴&#xff0c;我们的团队掌握目前市面上大部分车载平台的ISP图像画质服务能力&#xff0c;能自主开发图像ISP和增强算法。我们具有多名经验丰富光学设计专家&#xff0c;掌握车载模组光学设计能力&#xff0c;资深…

Mac上如何安装低版本chrome浏览器

背景 为了排查项目上使用chrome低版本的兼容性问题&#xff0c;需要在本机【mac系统】上安装一个低版本的chrome浏览器。 不同版本的chrome下载地址 https://www.slimjet.com/chrome/google-chrome-old-version.php 下载后要记得你下载的旧版本的版本号&#xff0c;后面修改…

Neural Filters:着色

Ps菜单&#xff1a;滤镜/Neural Filters/颜色/着色 Neural Filters/COLOR/Colorize 着色 Colorize滤镜可以对黑白照片自动着色&#xff0c;也为彩色照片简化色彩提供了有力的支持。 “着色”滤镜利用深度学习技术&#xff0c;对输入的黑白或彩色照片进行分析&#xff0c;识别图…

【云原生】kubernetes声明式管理-----YAML文件

目录 引言 一、声明式管理简介 &#xff08;一&#xff09;什么是声明式管理 &#xff08;二&#xff09;支持格式 二、YAML文件 &#xff08;一&#xff09;YAML文件基本格式 &#xff08;二&#xff09;YAML文件实践 三、YAML文件创建方式 &#xff08;一&#xff0…

rk3568_spinlock

文章目录 前言1、spinlock是什么?2、自旋锁实验2.1源码2.2 结果图总结前言 本文记录在rk3568开发板做的自旋锁实验。通过自旋锁控制state变量来限制只有一个应用程序来打开驱动设备。 1、spinlock是什么? spinlock称为自旋锁,如果获取不到资源,就只能一直傻傻地等待资源被…

B树与B+树区别

B树和B树是常见的数据库索引结构&#xff0c;都具有相较于二叉树层级较少&#xff0c;查找效率高的特点&#xff0c;它们之间有以下几个主要区别&#xff1a; 1.节点存储数据的方式不同 B树的叶子结点和非叶子节点都会存储数据&#xff0c;指针和数据共同保存在同一节点中B树…

一文教你使用stream流轻松解决java项目数据枚举显示问题

本篇文章主要讲解java枚举、vo实体类通过stream流形式输出枚举参数的方法。 日期&#xff1a;2024年5月26日 作者&#xff1a;任聪聪 本文代码实例附件&#xff1a;https://download.csdn.net/download/hj960511/89361611 实际效果 可以看到在枚举参数的基础上&#xff0c;我们…

这或许是国产游戏出海的最佳时机

《刺客信条&#xff1a;影》过于政治正确的选角激怒了全球玩家&#xff0c;而社交媒体上有玩家讨论育碧是否应该因为刻意加入DEI&#xff08;多元化&#xff09;而延期《刺客信条&#xff1a;影》时&#xff0c;没想到这得到了X拥有人埃隆马斯克的回复。马斯克表示“DEI&#x…

【Chrono Engine学习总结】6-创建自定义场景-6.2-chrono中的光线设置

由于Chrono的官方教程在一些细节方面解释的并不清楚&#xff0c;自己做了一些尝试&#xff0c;做学习总结。 上一篇文章中&#xff0c;自己【用sketchup重建了三维场景】&#xff0c;但导入chrono中颜色很不正确&#xff0c;几乎都是白色的&#xff0c;但也不是完全白色。经过…

宿舍管理系统代码详解(操作界面)

目录 一、前端代码 1.样式展示 2.代码详解 <1>主页面列表部分 &#xff08;1&#xff09;template部分 &#xff08;2&#xff09;script部分 <2>新增页面 &#xff08;1&#xff09;template部分 &#xff08;2&#xff09;script部分 <3>修改页面…

Mongodb介绍及springboot集成增删改查

文章目录 1. MongoDB相关概念1.1 业务应用场景1.2 MongoDB简介1.3 体系结构1.4 数据模型1.5 MongoDB的特点 2. docker安装mongodb3. springboot集成3.1 文件结构3.2 增删改查3.2.1 增加insert3.2.2 保存save3.2.3 更新update3.2.4 查询3.2.5 删除 1. MongoDB相关概念 1.1 业务…

vue3快速入门(局部使用)

目录 前置知识JavaScript-导入导出 入门操作 变量渲染页面 局部使用vue的实现步骤 vue指令 v-for v-bind v-if v-show v-on v-model 生命周期 前置知识JavaScript-导入导出 正常情况在html导入js文件是全部导入&#xff0c;这样会导致性能上的损失 。 JS提供的…