CS-第 5 周

数据结构详解:从数组到树,再到哈希表

本文深入探讨几种常见的数据结构,包括数组、链表、二叉搜索树(BST)和哈希表,并阐述其在内存中的组织方式及优缺点。

信息结构与抽象数据结构

信息结构指的是内存中组织信息的方式,而抽象数据结构则是我们概念上对这些结构的理解。 理解抽象数据结构有助于我们更好地在实践中实现各种数据结构。

堆栈和队列

队列是一种遵循FIFO(先进先出)原则的抽象数据结构,类似于排队等候。其主要操作包括入队(添加元素到队列尾部)和出队(移除队列头部元素)。

堆栈则遵循LIFO(后进先出)原则,如同叠盘子。其操作包括压入(添加元素到堆栈顶部)和弹出(移除堆栈顶部元素)。

数组

数组是一种在内存中连续存储数据的结构。 如下图所示,数组在内存中占据连续的存储空间。

CS-第 5 周

内存中可能存在其他程序、函数和变量,以及之前使用过的冗余数据。 如果需要向数组添加新元素,则需要重新分配内存并复制整个数组,这会造成效率低下。

CS-第 5 周CS-第 5 周CS-第 5 周

预先分配过多的内存虽然可以减少复制操作,但却会浪费系统资源。因此,根据实际需求分配内存至关重要。

链表

链表是一种强大的数据结构,它允许将位于不同内存区域的值连接成一个列表,并支持动态扩展或缩小。

CS-第 5 周

每个节点包含两个值:数据值和指向下一个节点的指针。最后一个节点的指针值为NULL,表示链表的结尾。

CS-第 5 周CS-第 5 周

C语言中,节点可以定义如下:

typedef struct node {    int number;    struct node *next;} node;

以下示例展示了链表的创建过程:

CS-第 5 周nodeCS-第 5 周CS-第 5 周CS-第 5 周CS-第 5 周CS-第 5 周CS-第 5 周

链表的缺点包括:需要额外内存存储指针,以及无法通过索引直接访问元素。

二叉搜索树 (BST)

二叉搜索树是一种高效存储、搜索和检索数据的树形结构。

CS-第 5 周CS-第 5 周CS-第 5 周

BST 的优点在于动态性和搜索效率(O(log n)),缺点在于树不平衡时搜索效率会下降到 O(n),并且需要额外的内存存储指针。

哈希表

哈希表类似于字典,包含键值对。 它利用哈希函数将键映射到数组索引,从而实现 O(1) 的平均查找时间。

CS-第 5 周

哈希冲突(多个键映射到同一个索引)可以通过链表或其他方法解决。 哈希函数的设计对哈希表的性能至关重要。 一个简单的哈希函数示例如下:

#include unsigned int hash(const char *word) {    return toupper(word[0]) - 'A';}

本文基于cs50x 2024源码整理。

以上就是CS-第 5 周的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1461260.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
使用gdb快速调试
上一篇 2025年12月18日 13:11:32
c语言函数的嵌套调用和递归调用分别是啥意思
下一篇 2025年12月18日 13:11:45

相关推荐

  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • python中numpy的用法

    NumPy是Python中用于科学计算的强大库,它提供了以下功能:多维数组处理矩阵运算快速傅里叶变换(FFT)线性代数随机数生成 NumPy在Python中的强大功能 NumPy是Python中用于科学计算的一个强大且灵活的库。它提供了用于处理多维数组和矩阵的一组高效工具,是数据分析和机器学习项目的…

    2026年5月10日
    100
  • c++中头文件和源文件的区别_c++头文件与源文件作用对比

    头文件声明接口,源文件实现逻辑。头文件含类、函数声明及宏定义,通过#include被多文件共享,用include守卫防重;源文件实现具体功能,编译为目标文件后由链接器合并。声明与实现分离提升模块化与编译效率,模板和内联函数因需编译时可见故常置于头文件,命名空间避免符号冲突,整体结构使项目更清晰易维护…

    2026年5月10日
    000
  • c语言short怎么设置

    C语言中short类型数据为16位有符号整数,范围[-32768, 32767]。设置方法:1. 声明short变量(如:short myShort = 123;);2. 使用短整型字面量(如:myShort = 123S;);3. 使用类型转换(如:short myShort = (short) …

    2026年5月10日
    000
  • 深入理解 Laravel Session::put:避免常见陷阱与实现表单限流

    本文旨在深入探讨 laravel 框架中 `session::put` 方法的正确用法及其常见误区。针对用户在实现表单提交限流时遇到的问题,详细阐述了 `session::put` 必须提供键值对的原理,并提供了如何在控制器中利用会话机制有效防止重复提交的实战代码示例。通过本文,读者将掌握 lara…

    2026年5月10日
    000
  • WebAssembly中导入JavaScript函数:无胶水代码集成指南

    本文深入探讨了在WebAssembly模块中直接导入和使用JavaScript函数的机制,特别是当使用Emscripten的STANDALONE_WASM和SIDE_MODULE编译模式时。文章详细分析了TypeError: import object field ‘GOT.mem&#8…

    2026年5月10日
    000
  • JS注解怎么和TypeScript结合_ JS注解在TypeScript环境下的应用

    TypeScript 支持通过配置 allowJs 和 checkJs 在 JavaScript 文件中识别 JSDoc 注解并进行类型检查,可在混合项目中提升类型安全;常见用法包括 @type、@param、@returns 和 @typedef,能为变量、函数参数等提供类型信息,支持与 .ts …

    2026年5月10日
    000
  • jQuery对象类型判断机制详解:toType函数如何精准识别对象类型?

    深入解析jquery对象类型判断机制:totype函数详解 本文将深入剖析jQuery中用于精准识别对象类型的toType函数,并详细解释其核心代码片段。该函数旨在判断传入对象的类型并返回其类型字符串。 核心代码如下: var class2type = {};var toString = class…

    2026年5月10日
    000
  • JavaScript中为动态列表元素创建唯一悬停描述的教程

    本教程旨在解决如何为动态生成的列表或数组元素分配唯一悬停描述(tooltip)的问题。文章将深入探讨使用javascript对象和map数据结构来高效地管理名称与描述的映射关系,并提供具体的代码示例,以实现每个列表项在鼠标悬停时显示不同的自定义信息,同时兼顾性能与数据顺序的需求。 在网页开发中,我们…

    2026年5月10日
    000
  • c语言整除函数怎么表示

    C语言中进行整数除法的函数是 /,其语法为 result = dividend / divisor,结果取整且不会有小数部分。 C 语言整除函数表示方法 C 语言中,用于进行整数除法的函数是 /。 语法: result = dividend / divisor; 其中: 立即学习“C语言免费学习笔记…

    2026年5月10日
    000
  • PHP中通过键名高效关联与输出多维数组数据

    本教程旨在解决php开发中常见的数据关联与输出问题,特别是当需要将不同数组中通过共同键名关联的数据进行整合展示时。文章将详细阐述如何利用foreach循环的键值对特性,结合array_key_exists函数,实现从多个数组中提取并组合相关信息,从而避免不必要的嵌套循环,提升代码的清晰度和执行效率。…

    2026年5月10日
    000
  • 人工智能如何为 C 语言代码提供安全增强功能?

    人工智能通过提供以下功能来提升 c 代码安全性:静态分析:识别潜在安全漏洞(例如缓冲区溢出);动态分析:监控代码执行并检测异常行为;模糊测试:生成随机输入以测试代码的异常行为;自动化修复:建议修复措施或自动生成补丁程序。 人工智能赋能 C 代码:提升安全性 人工智能 (AI) 在 C 代码安全方面发…

    2026年5月10日
    100
  • Go语言Cgo代码GDB调试失效:Go 1.1版本下的挑战与官方进展

    本文探讨了go语言程序中cgo代码在使用gdb进行调试时遇到的挑战,特别指出go 1.1版本中存在的变量值显示异常问题。该问题是一个已知的官方缺陷(go issue 5221),导致在cgo交互部分gdb调试功能失效,而go 1.0版本则无此问题。文章将通过示例代码重现该现象,并阐述其根源及官方的解…

    2026年5月10日
    000
  • python中怎么删除字典中的键值对_Python删除字典元素的方法

    删除字典键值对有四种方法:del语句删除指定键,pop()删除键并返回值,popitem()随机删除键值对,clear()清空字典。 在 Python 中,删除字典中的键值对主要有几种方式:使用 del 语句直接删除指定键,利用 pop() 方法删除指定键并获取其对应的值,或者通过 popitem(…

    2026年5月10日
    000
  • 怎样用Golang实现一个简单的键值存储 基于文件持久化方案

    怎样用Golang实现一个简单的键值存储 基于文件持久化方案怎样用Golang实现一个简单的键值存储 基于文件持久化方案怎样用Golang实现一个简单的键值存储 基于文件持久化方案怎样用Golang实现一个简单的键值存储 基于文件持久化方案

    要实现一个简单的键值存储系统,需结合golang与文件持久化方案。1. 使用map[string]string作为内存数据结构,选择json或gob进行序列化;2. 围绕map实现crud操作,写入后立即或定时刷新到磁盘,并在启动时加载数据;3. 文件策略可选每次写入刷盘、定时异步刷盘或日志记录变更…

    2026年5月10日 用户投稿
    000
  • c语言中free(f)的意思

    c语言中free(f)的含义 free(f) 函数在 C 语言中释放由 malloc()、calloc() 或 realloc() 等函数动态分配的内存块。 作用: 释放动态分配的内存块。将指针 f 设置为 NULL。 语法: void free(void *f); 参数: 立即学习“C语言免费学习…

    用户投稿 2026年5月10日
    000
  • c语言中x*x是什么意思

    在 C 语言中,x*x 表示 x 与自身相乘的结果,即 x 的平方。它对应于数学中的 x²,优先级高于加减运算。用于计算面积、体积和求解二次方程,但需要注意浮点数精度可能导致轻微偏差。 x*x 在 C 语言中的含义 在 C 语言中,x*x 表示 x 与自身相乘的结果,即 x 的平方。它对应于数学中的…

    2026年5月10日
    000
  • C++ 数据结构指南:理清复杂数据组织之道

    答案: c++++ 数据结构是组织和管理数据的构建块,优化检索和处理。常见结构:数组:有序集合,通过索引访问向量:动态数组,快速插入和删除链表:灵活插入和删除堆栈:lifo 原则队列:fifo 原则树:分层结构哈希表:快速键值查找应用: 数据存储、算法设计、图形处理、人工智能等。实战案例: 使用学生…

    2026年5月10日
    000
  • 从LocalStorage中获取并显示特定JSON对象属性的教程

    本文详细介绍了如何从浏览器localstorage中检索存储为json字符串的复杂数据,并提取其中的特定属性值以显示在网页元素中。核心方法是使用`json.parse()`将存储的字符串转换回javascript对象,然后通过点或方括号语法访问所需属性。文章还提供了示例代码和错误处理建议,确保数据获…

    2026年5月10日
    100
  • c语言里面字符是什么意思

    字符在 C 语言中以单个字节存储于 char 变量中,用单引号括起表示常量,例如 ‘A’。字符变量用于存储字符值,可使用函数如 putchar() 输出、getchar() 输入、toupper() 转换大小写。字符数组存储多个字符,如 char name[10]。字符串是带…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信