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

C26.【C++ Cont】动态内存管理和面向对象的方式实现链表

🧨🧨🧨🧨🧨🧨🧨🧨🧨除夕篇🧨🧨🧨🧨🧨🧨🧨🧨🧨

目录

1.知识回顾

2.两个操作符

new操作符

示例代码1:申请一个变量

示例代码2:申请连续的内存空间

delete操作符

示例代码3


1.知识回顾

C语言中的动态内存管理知识回顾:

68.【C语言】动态内存管理(重点)(1)

69.【C语言】动态内存管理(重点)(2)

70.【C语言】动态内存管理(重点)(3)

71.【C语言】动态内存管理(重点)(4)

E37.【C语言】动态内存管理练习题

2.两个操作符

和C语言一样,在堆区上自行申请空间和释放空间,注意:new和delete应该配对使用

new操作符

new申请一个变量的空间,new[ ]申请一个数组的空间

new返回的是申请到的内存空间的起始地址,因此需要指针来接收

示例代码1:申请一个变量

格式:new 数据类型 或 new 数据类型(初始值)

//p1指向申请的int类型的空间,但未初始化
int* p1 = new int;
if (p1==nullptr)
{perror("new");return 1;
}//p2指向申请的int类型的空间,已初始化为5
int* p2 = new int(5); 
if (p2==nullptr)
{perror("new");return 1;
}

注:为防止new开辟空间失败,建议判断p1和p2是否为空,或者assert断言

VS2022调试模式下在内存窗口输入&p1

再跳到0x0128a288查看,4字节的cd,显然未初始化

VS2022调试模式下在内存窗口输入&p2

再跳到0x0128a2b8查看,为05 00 00 00,已初始化为5

示例代码2:申请连续的内存空间

申请连续的内存空间即申请数组空间

格式:new 数据类型[元素个数]

int* p3 = new int[10];//申请10个int类型的空间

注:new不是只能给内置类型开辟空间,也可以给自定义类型开辟空间,例如结构体

delete操作符

delete负责释放一个变量的空间,delete[ ]释放一个数组的空间

格式:delete 指针 或 delete[] 指针(数组的空间)

示例代码3

	int* p1 = new int;if (p1==nullptr){perror("new");return 1;}int* p2 = new int(5);if (p2==nullptr){perror("new");return 1;}int* p3 = new int[10];if (p1==nullptr){perror("new");return 1;}delete p1;p1 = nullptr;delete p2;p2 = nullptr;delete[] p3;p3 = nullptr;

要养成良好的习惯,delete后防止野指针要手动为指针置空

有关malloc和new,delete和free的区别这里不做讲解,竞赛中只需要知道怎么用就行

注意:在竞赛中数据结构的模拟实现不会采用malloc和free或者 new 和 delete 的方式,代码量大和运行速度慢而是采用静态的足够大的数组来模拟实现

3.面向对象的方式实现链表

1.知识回顾

63.【C语言】再议结构体(上)
86.【C语言】数据结构之链表的总体概述

87.【C语言】数据结构之链表的头插和尾插

91.【C语言】数据结构之单向链表的头删和尾删

92.【C语言】数据结构之单向链表的查找,中间插入和删除,销毁

上面的这些文章实际上是面向过程的方式实现链表

2.面向对象的方式实现

竞赛中一般使用数组去模拟链表,这里简单了解就行

面向对象的方式:可以使用结构体去封装链表的各个操作(隐藏对象的内部实现细节,只暴露必要的接口供外部使用),之后借助点操作符去调用成员函数

(有关C++结构体的内容参见C24.【C++ Cont】结构体文章)

实现代码

struct List
{Node* phead;//指向头节点的指针Node* ptail;//指向尾节点的指针List()//构造函数用于初始化指向头节点的指针{phead = nullptr;ptail = nullptr;}~List()//析构函数用于销毁链表{while (phead){SLTPopFront();}phead = nullptr;ptail = nullptr;}Node* BuySLTNode(SLTDataType x)//新建节点{Node* newnode = new  Node;if (newnode == nullptr){perror("new");return nullptr;}newnode->val = x;newnode->next = nullptr;return newnode;}void SLTPushFront(SLTDataType x)//头插节点{Node* newnode = BuySLTNode(x);if (phead == nullptr){phead = ptail= newnode;}else{newnode->next = phead;phead = newnode;//不用改动ptail}}void SLTPushBack(SLTDataType x)//尾插节点{Node* newnode = BuySLTNode(x);if (phead == nullptr){ptail = phead = newnode;//如果是第一次插入需要同时更新首尾指针}else{ptail->next = newnode;ptail = ptail->next;}}void SLTPopFront()//头删节点{if (phead == nullptr){cout << "链表为空,禁止头删" << endl;return;}Node* tmp = phead;phead = tmp->next;delete tmp;tmp = nullptr;}void SLTPopBack()//尾删节点{if (phead == nullptr){cout << "链表为空,禁止尾删" << endl;return;}Node* tmp = phead;if (phead->next == nullptr){delete phead;ptail= phead = nullptr;//删除最后一个节点,注意将首尾指针都置为空return;}while (tmp->next != ptail)//寻找尾节点前面的节点{tmp = tmp->next;}delete ptail;ptail = tmp;ptail->next = nullptr;tmp = nullptr;}void SLTPrint()//打印链表的所有节点{Node* cur = phead;while (cur){cout << cur->val << "-->";cur = cur->next;}cout << "NULL"<<endl;}
};

如果用类写:

class List
{private:Node* phead;Node* ptail;public:List(){//......}~List(){//......}Node* BuySLTNode(SLTDataType x){//......}void SLTPushFront(SLTDataType x){//......}void SLTPushBack(SLTDataType x){//......}void SLTPopFront(){//......}void SLTPopBack(){//......}void SLTPrint(){//......}
};

封装后的接口说明

只需要向开发者提供接口说明,供开发者调用,例如:

/
//文件名:list.cpp
//作者:zhancod
//版本:v1.0
//完成日期:2025.1.28
//修改记录:......
//
//描述:单链表API
//提醒:1.使用前先创建链表(List list;),之后调用接口函数(list.函数(?))
//     2.链表存储的数据类型定义在typedef  int SLTDataType;
//     3.不需要手动new和delete链表
//
//1.函数:SLTPushFront
//  功能:头插节点
//  使用方式:list.SLTPushFront(data)
//
//2.函数:SLTPushBack
//  功能:尾插节点
//  使用方式:list.SLTPushBack(data)
//
//3.函数:SLTPopFront
//  功能:头删节点
//  使用方式:list.SLTPopFront()
//
//4.函数:SLTPopBack
//  功能:尾删节点
//  使用方式:list.SLTPopBack()
//
//5.函数:SLTPrint
//  功能:打印链表的所有节点
//  使用方式:list.SLTPrint()
//

调用接口的代码

int  main()
{{List list;list.SLTPushFront(1);list.SLTPushBack(2);list.SLTPushFront(3);list.SLTPushBack(4);list.SLTPushFront(5);list.SLTPopFront();list.SLTPrint();list.SLTPopBack();list.SLTPrint();list.SLTPopBack();list.SLTPopFront();list.SLTPopBack();list.SLTPopFront();list.SLTPopBack();list.SLTPrint();}return 0;
}

执行结果

练习

稍微修改上方的代码可以提交本题:707. 设计链表 - 力扣(LeetCode)

之后会单独出一篇文章讲解

🎉❤️🎉❤️🎉❤️🎉❤️🎉❤️祝各位码农们蛇年大吉 巳巳如意!❤️🎉❤️🎉❤️🎉❤️🎉❤️🎉

相关文章:

C26.【C++ Cont】动态内存管理和面向对象的方式实现链表

&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;除夕篇&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8; 目录 1.知识回顾…...

使用numpy自定义数据集 使用tensorflow框架实现逻辑回归并保存模型,然后保存模型后再加载模型进行预

1. 引言 逻辑回归&#xff08;Logistic Regression&#xff09;是一种常见的分类算法&#xff0c;广泛应用于二分类问题。在本篇博客中&#xff0c;我们将使用numpy生成一个简单的自定义数据集&#xff0c;并使用TensorFlow框架构建和训练逻辑回归模型。训练完成后&#xff0c…...

Java Web 开发基础介绍

Java学习资料 Java学习资料 Java学习资料 一、引言 在当今数字化时代&#xff0c;Web 应用无处不在。Java 凭借其强大的功能、良好的跨平台性和丰富的开发框架&#xff0c;成为 Web 开发领域的热门选择之一。Java Web 开发允许开发者构建动态、交互式的 Web 应用程序&#x…...

求解旅行商问题的三种精确性建模方法,性能差距巨大

文章目录 旅行商问题介绍三种模型对比求解模型1决策变量目标函数约束条件Python代码 求解模型2决策变量目标函数约束条件Python代码 求解模型3决策变量目标函数约束条件Python代码 三个模型的优势与不足 旅行商问题介绍 旅行商问题 (Traveling Salesman Problem, TSP) 是一个经…...

C++:多继承习题3

题目内容&#xff1a; 声明一个时间类Time&#xff0c;时间类中有3个私有数据成员(Hour&#xff0c;Minute&#xff0c;Second)和两个公有成员函数(SetTime和PrintTime)。要求&#xff1a; &#xff08;1&#xff09; SetTime根据传递的3个参数为对象设置时间&#xff1b; &a…...

低代码系统-产品架构案例介绍、得帆云(八)

产品名称 得帆云DeCode低代码平台-私有化 得帆云DeMDM主数据管理平台 得帆云DeCode低代码平台-公有云 得帆云DePortal企业门户 得帆云DeFusion融合集成平台 得帆云DeHoop数据中台 名词 概念 云原生 指自己搭建的运维平台&#xff0c;区别于阿里云、腾讯云 Dehoop 指…...

python Flask-Redis 连接远程redis

当使用Flask-Redis连接远程Redis时&#xff0c;首先需要安装Flask-Redis库。可以通过以下命令进行安装&#xff1a; pip install Flask-Redis然后&#xff0c;你可以使用以下示例代码连接远程Redis&#xff1a; from flask import Flask from flask_redis import FlaskRedisa…...

【Unity3D】实现Decal贴花效果,模拟战旗游戏地形效果

目录 一、基础版 二、Post Process 辉光Bloom效果 矩形渐隐 涉及知识点&#xff1a;Decal贴花、屏幕后处理Bloom、屏幕空间构建世界空间、ChracterController物体移动、Terrain地形创建 一、基础版 Unity 2019.4.0f1 普通渲染管线&#xff08;非URP、非HDRP&#xff09; UR…...

实践网络安全:常见威胁与应对策略详解

&#x1f4dd;个人主页&#x1f339;&#xff1a;一ge科研小菜鸡-CSDN博客 &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; 引言 在数字化转型的浪潮中&#xff0c;网络安全的重要性已达到前所未有的高度。无论是个人用户、企业&#xff0c;还是政府机构…...

《 C++ 点滴漫谈: 二十四 》深入 C++ 变量与类型的世界:高性能编程的根基

摘要 本文深入探讨了 C 中变量与类型的方方面面&#xff0c;包括变量的基本概念、基本与复合数据类型、动态类型与内存管理、类型推导与模板支持&#xff0c;以及类型系统的高级特性。通过全面的理论讲解与实际案例分析&#xff0c;展示了 C 类型系统的强大灵活性与实践价值。…...

UART、I2C和SPI对比

UARTSPII2C英文Universal Asynchronous Receive/TransmitSerial Peripheral InterfaceInner Integrated Communication通讯速度115200、38400 bit/s高达100M bit/s 100k、400k、1M、3.4M bit/s时钟同/异步性时钟异步时钟同步时钟同步接线方式3线(Rx、Tx、GND) 4线(MISO、…...

开源项目Umami网站统计MySQL8.0版本Docker+Linux安装部署教程

Umami是什么&#xff1f; Umami是一个开源项目&#xff0c;简单、快速、专注用户隐私的网站统计项目。 下面来介绍如何本地安装部署Umami项目&#xff0c;进行你的网站统计接入。特别对于首次使用docker的萌新有非常好的指导、参考和帮助作用。 Umami的github和docker镜像地…...

C# INotifyPropertyChanged接口在list类型中的应用

我们在项目开发时遇到监听List<T>中成员的值发生变化。我们一般使用INotifyPropertyChanged...

KIMI K1.5:用大语言模型扩展强化学习(论文翻译)

文章目录 KIMI K1.5技术报告摘要 1. 引言2. 方法&#xff1a;基于大语言模型的强化学习2.1 强化学习提示集整理2.2 长思维链监督微调2.3 强化学习2.3.1 问题设定2.3.2 策略优化2.3.3 长度惩罚2.3.4 采样策略2.3.5 训练方法的更多细节 2.4 长到短&#xff1a;短思维链模型的上下…...

Kiwi 安卓浏览器本月停止维护,扩展功能迁移至 Edge Canary

IT之家 1 月 25 日消息&#xff0c;科技媒体 Android Authority 今天&#xff08;1 月 25 日&#xff09;发布博文&#xff0c;报道称 Kiwi 安卓浏览器将于本月停止维护&#xff0c;相关扩展支持功能已整合到微软 Edge Canary 浏览器中。 开发者 Arnaud42 表示 Kiwi 安卓浏览器…...

思科交换机telnet配置案例

目录 1.telnet简述2.网络拓扑3.设备说明4.网络配置4.1 电脑PC ip设置4.2 网络交换机telnet配置 5.小结 1.telnet简述 Telnet是远程登录服务的一个协议&#xff0c;该协议定义了远程登录用户与服务器交互的方式。它允许用户在一台联网的计算机上登录到一个远程分时系统中&#…...

计算机毕业设计Django+Tensorflow音乐推荐系统 机器学习 深度学习 音乐可视化 音乐爬虫 知识图谱 混合神经网络推荐算法 大数据毕设

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 作者简介&#xff1a;Java领…...

基于蓝牙6.0的RSSI和UWB融合定位方法,可行性分析

融合RSSI&#xff08;接收信号强度指示&#xff09;和UWB&#xff08;超宽带&#xff09;两种技术进行蓝牙6.0定位是完全可行的&#xff0c;并且可以带来更高的定位精度和稳定性。本文给出分析和MATLAB仿真结果 文章目录 技术优势RSSIUWB融合的优势 实现方案数据融合算法硬件要…...

【开源免费】基于Vue和SpringBoot的在线文档管理系统(附论文)

本文项目编号 T 038 &#xff0c;文末自助获取源码 \color{red}{T038&#xff0c;文末自助获取源码} T038&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析 六、核心代码6.1 查…...

【Elasticsearch】 索引模板 ignore_missing_component_templates

解释 ignore_missing_component_templates 配置 在Elasticsearch中&#xff0c;ignore_missing_component_templates 是一个配置选项&#xff0c;用于处理索引模板中引用的组件模板可能不存在的情况。当您创建一个索引模板时&#xff0c;可以指定一个或多个组件模板&#xff0…...

AI DeepSeek

DeepSeek 文字解析 上传图片解析 视乎结果出入很大啊&#xff0c;或许我们应该描述更加清楚自己的需求。...

QT使用eigen

QT使用eigen 1. 下载eigen https://eigen.tuxfamily.org/index.php?titleMain_Page#Download 下载后解压 2. QT引入eigen eigen源码好像只有头文件&#xff0c;因此只需要引入头文件就好了 qt新建项目后。修改pro文件. INCLUDEPATH E:\222078\qt\eigen-3.4.0\eigen-3.…...

C#面试常考随笔6:ArrayList和 List的主要区别?

在 C# 中&#xff0c;ArrayList和List<T>&#xff08;泛型列表&#xff09;都可用于存储一组对象。推荐优先使用List<T>&#xff0c;因为它具有更好的类型安全性、性能和语法简洁性&#xff0c;并且提供了更丰富的功能。只有在需要与旧代码兼容或存储不同类型对象的…...

mysql学习笔记-数据库其他调优策略

1、如何定位调优问题 用户的反馈&#xff08;主要&#xff09; 日志分析&#xff08;主要&#xff09; 服务器资源使用监控 数据库内部状况监控 2、调优的维度和步骤 第1步&#xff1a;选择适合的 DBMS 第2步&#xff1a;优化表设计 第3步&#xff1a;优化逻辑查询 第4步&am…...

HTB:Forest[WriteUP]

连接至HTB服务器并启动靶机 分配IP&#xff1a;10.10.16.21 靶机IP&#xff1a;10.10.10.161 靶机Domain&#xff1a;forest.htb 目录 连接至HTB服务器并启动靶机 信息收集 使用rustscan对靶机TCP端口进行开放扫描 将靶机TCP开放端口号提取并保存 使用nmap对靶机TCP开放端…...

实验七 带函数查询和综合查询(2)

1 检索至少选修课程“数据结构”和“C语言”的学生学号 方法一&#xff1a; select Stu_id from StudentGrade,Course where Course.Course_idStudentGrade.Course_id and Course_name‘数据结构’ and Stu_id in (select Stu_id from StudentGrade,Course where Course.Course…...

Bootloader升级功能实现:从理论到工程实践

Bootloader升级功能实现:从原理到工程实践 目录 Bootloader升级功能实现:从原理到工程实践引言1. Bootloader架构解析1.1 分层架构设计1.2 典型启动流程2. 关键设计要素2.1 内存分区规划2.2 看门狗管理策略3. 通信协议实现3.1 基于UDS的升级协议3.2 报文格式规范4. 六大典型案…...

物业软件推动物业行业数字化转型 实现高效管理和优质客户体验

内容概要 在当今高速发展的数字化时代&#xff0c;物业软件的出现不仅使物业管理变得更加高效&#xff0c;也为行业转型提供了强大的支持。通过整合多种功能&#xff0c;物业软件显著提升了管理效率和客户体验。例如&#xff0c;在线收费和停车管理功能&#xff0c;让业主享受…...

GO 库与框架篇

1. 需要重点掌握的库和框架? 输入输出: io,ioutil,fmt,bufio 字符处理: strings,bytes,strconv,regex,unicode,json 日期: 定时器-time.Tick,延时器-time.After/time.AfterFunc 数据库: database/sql 单元测试: testing 非类型安全操作: unsafe 同步:sync-同步操作,atomic-原子…...

24-25出差交流体会-25-01-28

简洁版 如果发现自己走下坡路&#xff0c;工资下降等&#xff0c;如何办&#xff1f; &#xff08;环境因素等不在此文讨论范围&#xff0c;个人无法改变大环境。&#xff09; 多思考&#xff0c;是否是自身已经具备的能力在新模式下大幅贬值。 出路只有一条&#xff0c;提升自…...