CMU15-445 Project.0总结

news2024/12/22 20:45:30

在线测试
在这里插入图片描述
本地测试
在这里插入图片描述

Project #0 - C++ Primer

以下是Project #0的网址,2022FALL的Project #0本质上是实现一棵字典树,关于字典树的相关内容可以参考C++实现字典树。

在本题中,为了存储对应着字符串的任意类型值,题目设计了一个Trie模板用于加速查询。我们可以将字符串中的每一个字符都当作是一个节点,根据字符之间的前后顺序我们可以构建出一个树结构,利用树结构进行查询能够避免我们每次都需要遍历所有存储的字符串,从而加快我们获得对应值的速度。

在每个节点当中,我们首先设计了最基础的节点类TrieNode,它包括了对应的字符key_char_,用于判断是否为字符串终点的布尔变量is_end_,以及用于记录子节点的哈希表children_。其中,在哈希表中以字符和unique_ptr为键值对进行存储。在TrieNode中,我们需要能够实现几个功能,包括了构造函数、移动构造函数、析构函数、根据key_char判断是否有对应的子节点、判断有无子节点、判断是否为字符串末端节点、获得当前节点对应的字符值、根据字符值和指向节点的指针插入新的子节点、根据字符值获得子节点、根据字符值删除子节点和修改布尔变量is_end_。

而后,我们设计了TrieNodeWithValue用于表示作为字符串终点的节点,它在其他方面与TrieNode类似,区别仅在于is_end_为真。同时我们给他添加了新属性value_用于表示字符串对应的值。在TrieNodeWithValue中,我们通向需要实现以下功能:构造函数、移动构造函数、析构函数、获得value_的值。

最后,我们需要设计Trie类,它整合了上述两个类,包括了根节点和读写锁。在Trie中,我们需要实现以下功能:构造函数、根据字符串和对应的值插入一系列新的节点、根据字符串删除一系列节点、根据字符串返回对应的值,并返回成功与否的标记。值得注意的是,我们在设计这三个函数时,还需要考虑多线程的实现。

总结

  1. 移动构造函数的第一个参数一定是一个右值引用(&&),同时需要确保移动之后源对象是销毁无害的,这也是右值引用的一个特点。使用移动构造函数代替拷贝构造函数不需要分配内存,更能节省空间。
  2. C++11提供了两种智能指针shared_ptr和unique_ptr,其区别体现在shared_ptr允许多指针指向同一对象,unique_ptr则独占所指向的对象。其中,考虑到unique_ptr独占的特性,我们能够利用这一特性来实现对象的管理,值得注意的是,这相应也会导致我们在函数中进行传参时无法直接使用unique_ptr,需要使用get函数将其转化为裸指针。也因为基于独占的特性,unique_ptr能够避免内存泄漏和更大的开销,更值得使用。
  3. forward函数与move函数类似,但forward函数能够保持原始实参的类型,能够确保其左右值不变化。
  4. 项目中内置的读写锁实际上是基于shared_mutex实现的,其函数内部也是对shared_mutex的调用。其特点体现在读写锁上,在进行读操作时所有线程都能够进行访问,在进行写操作时只能由一个线程进行独占。因此我们为了实现多线程操作,需要着重对写操作进行保护,即在插入和删除时需要使用读写锁。
  5. 我们在进行操作时需要多插入的多种情况进行考虑,并设计相应的操作:是新建节点还是转移原有节点。同时考虑到我们根据字符串进行遍历,因此当字符串遍历完成时我们抵达的节点就是末端节点,我们在末端节点的基础上对其进行修改即可。
  6. 考虑到节点不容易进行复制,我们可以直接新建节点或转移节点,使用reset函数进行更新。
  7. 在删除中,考虑到在一些情况下,我们需要删除一连串的节点,我们最终通过栈进行实现。我们在进行遍历时,将所有遍历到的节点指针都压入栈中,而后我们不断弹出栈顶元素,从下向上进行删除,若其子节点不为空且子节点有孩子则说明该子节点可能被其他字符串使用,不能进行删除,否则可以直接删除子节点。
  8. 在设计GetValue函数时,我们需要考虑返回类型不同的情况,最终使用强制转化dynamic_cast实现。若转换后指针不为空说明类型相同,否则success需要设置为false。
  9. 在执行clang-format时,发现提示无权限执行脚本文件。最后查找可以发现相应的文件权限为rw可读可写不可执行文件,我们可以使用sudo chmod -R 777 xxx来修改权限为rwx可读可写可执行文件,最后进行执行即可。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CV——day79 读论文:基于小目标检测的扩展特征金字塔网络

Extended Feature Pyramid Network for Small Object DetectionI. INTRODUCTIONII. RELATED WORKA. 深层物体探测器B. 跨尺度特征C. 目标检测中的超分辨率III. OUR APPROACHA. 扩展特征金字塔网络B. 特征纹理传输C. 交叉分辨蒸馏IV. EXPERIMENTSA. Experimental Settings1&…

SEATA是什么?它的四种分布式事务模式

一、SEATA是什么? Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务。Seata 将为用户提供了 AT、TCC、SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案。 在继续学习使用SEATA之前,对s…

电子科技大学数据库与软件工程实验五

适用于网工和物联网专业 期末考试会考 目录 一、实验目的 二、实验内容 三、实验软件 四、实验步骤及数据记录 1. 权限管理 2. 数据库备份 3. 生成 AWR 报告 五、实验结论及思考题 六、总结及心得体会 七、对本实验过程及方法、手段的改进建议 一、实验目的 1、掌握…

工作九年的机器人讲师收入如何

如下都是个人情况,供各位朋友参考,仅为个人情况,只代表我个人。为何写这样一篇博客:看了最近的热点我在一所普普通通的不知名高校工作了九年。如果问及我存款……我实在是非常非常惭愧的。真实数值如下(组合贷&#xf…

【数据库】第八章 数据库编程

第八章 数据库编程 8.1 嵌入式SQL&#xff08;C语言版&#xff09; 被嵌入的语言&#xff08;java ,C)等被称为宿主语言&#xff0c;简称主语言 当主语言 为 C 语言的时候 ​ 语法格式为 EXEC SQL <SQL语句>当主语言为java的时候 格式为 #SQL {<SQL语句>}以下讲解…

MATLAB | 如何解决实验数据散点图重叠问题(overlap)

本期部分实验效果&#xff1a; 这期讲一下如果数据重合严重该咋办(overlap)&#xff0c;事先说明&#xff0c;本文中的绘图均使用一个几行的简单小代码进行了修饰&#xff1a; function defualtAxes axgca;hold on;box on ax.XGridon; ax.YGridon; ax.XMinorTickon; ax.YMinor…

Redis 之企业级解决方案

文章目录一、缓存预热二、缓存雪崩三、缓存击穿四、缓存穿透五、性能指标监控5.1 监控指标5.2 监控方式&#x1f34c;benchmark&#x1f34c;monitor&#x1f34c;slowlog提示&#xff1a;以下是本篇文章正文内容&#xff0c;Redis系列学习将会持续更新 一、缓存预热 1.1 现象…

云服务器产生背景与历史演进

云服务器产生背景  业务量爆发和衰退周期考验后端服务器性能匹配 在传统IT架构中&#xff0c;需要提前预估业务爆发时间和业务量&#xff0c;提前部署服务器以支撑业务。但是&#xff0c;往往预估与实际结果是有差距的&#xff0c;预估量过大会造成服务器采购成本高&#x…

阿里巴巴内网 Java 面试 2000 题解析(2023 最新版)

前言 这份面试清单是今年 1 月份之后开始收集的&#xff0c;一方面是给公司招聘用&#xff0c;另一方面是想用它来挖掘在 Java 技术栈中&#xff0c;还有一些知识点是我还在探索的&#xff0c;我想找到这些技术盲点&#xff0c;然后修复它&#xff0c;以此来提高自己的技术水平…

2016年chatGPT之父Altman与马斯克的深度对话(值得一看)

2016年9月&#xff0c;现今OpenAI CEO&#xff0c;ChatGPT之父&#xff0c;时任创投公司Y Combinator的总裁Sam Altman在特斯拉加州弗里蒙特工厂采访了埃隆马斯克。马斯克阐述了创建OpenAI的初衷&#xff0c;以及就他而言&#xff0c;对于未来最为重要的五件事。这是OpenAI的两…

【概念辨析】大小端存储

一、情境 在进行内存调试窗口的查看时&#xff0c;是不是会有一种错觉&#xff0c;就是它存的数据与我们预期的都是颠倒的&#xff0c;比如&#xff1a; 这里的a就和我们预期的不是很相同。 二、大小端 大小端是计算机厂家根据自己的习惯制定的关于数据字节序的规则。 1.大端…

2023中职网络安全竞赛Web安全应用任务解析答案

Web安全应用 任务环境说明: 服务器场景:match_win03-4-1(关闭链接)服务器场景操作系统:Windows Server 2003 使用渗透机Kali Linux,访问靶机FTP服务,下载靶机网站中的部分源码并分析,将源码文件post.php中${flag1}空缺处应填写的函数作为Flag值提交。Flag:isset 使用…

程序设计语言(做题)

程序设计语言部分一、高级语言与低级语言1、低级语言&#xff08;面向机器&#xff09;2、高级语言&#xff08;面向对象&#xff09;二、编译程序与解释程序1、区别2、流程&#xff08;加粗点为不可省略过程&#xff0c;顺序不可变&#xff09;&#xff08;1&#xff09;词法分…

(指针内容)当你申请一个变量,在这期间内存会发生什么?

一. 前言C语言是比较偏底层的语言&#xff0c;为什么他比较偏底层&#xff0c;就是因为他的很多操作都是直接针对内存操作的。这篇我们就来讲解C语言的一大特点&#xff0c;也是难点&#xff0c;指针和指针操作。这篇文章我会先从基本类型的存储过程和原理讲起&#xff0c;然后…

【Docker】命令总结

目录 1.镜像命令 1.1拉取镜像 1.2查看镜像 1.3保存镜像 1.4导入镜像 2.容器命令 2.1创建并运行容器 2.2删除容器 2.3进入容器 2.4查看容器状态 2.5暂停容器 2.6恢复容器 2.7停止容器 2.8启动容器 2.8查看容器日志 3.数据卷命令 3.1创建数据卷 3.2查看所有数据…

C语言刷题(2)——“C”

各位CSDN的uu们你们好呀&#xff0c;今天小雅兰来复习一下之前所学过的内容噢&#xff0c;复习的方式&#xff0c;那当然是刷题啦&#xff0c;现在&#xff0c;就让我们进入C语言的世界吧 当然&#xff0c;题目还是来源于牛客网 完完全全零基础 编程语言初学训练营_在线编程题…

OP-TEE使用过程记录

1 项目概述 1.1项目需求 为确保用户的数据的安全&#xff0c;ARM公司提出了trustzone技术&#xff0c;个人将trustzone理解为cortex的虚拟化技术。在不增加硬件的情况下&#xff0c;使用trustzone技术达到硬件加密的效果。 1.2重点概念简要介绍 1.2.1 TrustZone机制&#x…

电子科技大学数据库与软件工程三

适用于网工和物联网专业 目录 一、实验目的 二、实验内容 三、实验软件 四、实验步骤及数据记录 1.子查询 2. 伪列 3.数据库对象 4. 块、存储过程和触发器 五、实验结论及思考题 实验结论&#xff1a; 思考题&#xff1a; 六、总结及心得体会 七、对本实验过程及方…

【华为OD机试模拟题】用 C++ 实现 - 关联子串(2023.Q1)

最近更新的博客 【华为OD机试模拟题】用 C++ 实现 - 获得完美走位(2023.Q1) 文章目录 最近更新的博客使用说明关联子串题目输入输出示例一输入输出说明示例一输入输出Code使用说明 参加华为od机试,一定要注意不要完全背诵代码,需要理解之后模仿写出,通过率才会高。 华…

Spring的Bean的生命周期,Bean的装配和注入

Spring容器启动获得BeanDefinition对象中有一个scope 属性。该属性控制着bean对象的作用域。本章节介绍Bean的作用域及生命周期&#xff0c;了解bean是怎么来的又怎么没的。 一、Bean的作用域 在Bean容器启动会读取bean的xml配置文件&#xff0c;然后将xml中每个bean元素分别转…