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

【静态链表】

#include stdio.h #include stdlib.h #define DEFAULT_SIZE 5 // 静态链表的容量包括头结点 /** * 静态链表节点结构 * 使用数组下标代替指针来实现链式存储 */ typedef struct StaticLinkedNode { char data; // 存储的字符数据 int next; // 下一个节点在数组中的下标-1表示空类似NULL } *NodePtr; // NodePtr是指向节点的指针类型 /** * 静态链表结构 * 管理整个静态链表的内存和状态 */ typedef struct StaticLinkedList { NodePtr nodes; // 指向节点数组的指针动态分配 int* used; // 标记数组1表示该位置已被使用0表示空闲 } *ListPtr; // ListPtr是指向链表管理器的指针类型 /** * 初始化静态链表 * return 返回初始化后的链表管理器指针 */ ListPtr initLinkedList() { // 1. 为链表管理器分配内存 ListPtr tempPtr (ListPtr)malloc(sizeof(struct StaticLinkedList)); // 2. 为节点数组分配内存DEFAULT_SIZE个节点 tempPtr-nodes (NodePtr)malloc(sizeof(struct StaticLinkedNode) * DEFAULT_SIZE); // 3. 为used标记数组分配内存 tempPtr-used (int*)malloc(sizeof(int) * DEFAULT_SIZE); // 4. 初始化头结点下标0 tempPtr-nodes[0].data \0; // 头结点不存储有效数据 tempPtr-nodes[0].next -1; // -1表示空链表 // 5. 初始化used数组 tempPtr-used[0] 1; // 头结点被占用 for (int i 1; i DEFAULT_SIZE; i) { tempPtr-used[i] 0; // 其他位置空闲 } return tempPtr; } /** * 释放链表占用的所有内存 * param paraListPtr 链表管理器指针 */ void freeLinkedList(ListPtr paraListPtr) { if (paraListPtr NULL) return; // 空指针检查 free(paraListPtr-nodes); // 释放节点数组 free(paraListPtr-used); // 释放标记数组 free(paraListPtr); // 释放管理器本身 } /** * 打印链表中的所有字符 * param paraListPtr 链表管理器指针 */ void printList(ListPtr paraListPtr) { int p paraListPtr-nodes[0].next; // 从头结点的下一个节点开始 while (p ! -1) { // 遍历直到链表末尾-1 printf(%c, paraListPtr-nodes[p].data); // 打印当前节点的数据 p paraListPtr-nodes[p].next; // 移动到下一个节点 } printf(\n); } /** * 在指定位置插入字符 * param paraListPtr 链表管理器指针 * param paraChar 要插入的字符 * param paraPosition 插入位置0表示插入到链表头部 */ void insertElement(ListPtr paraListPtr, char paraChar, int paraPosition) { int p, q, i; // 步骤1找到插入位置的前一个节点前驱 p 0; // 从头结点开始 for (i 0; i paraPosition; i) { p paraListPtr-nodes[p].next; // 向后移动 if (p -1) { // 如果到达链表末尾说明位置越界 printf(The position %d is beyond the scope of the list.\n, paraPosition); return; } } // 步骤2在节点数组中找一个空闲位置模拟内存分配 for (i 1; i DEFAULT_SIZE; i) { // 从下标1开始跳过0号头结点 if (paraListPtr-used[i] 0) { // 找到空闲位置 printf(Space at %d allocated.\n, i); paraListPtr-used[i] 1; // 标记为已使用 q i; // 记录新节点的下标 break; } } // 检查是否找到空闲位置 if (i DEFAULT_SIZE) { printf(No space.\n); // 静态链表已满 return; } // 步骤3将数据存入新节点 paraListPtr-nodes[q].data paraChar; // 步骤4修改指针完成插入操作 // 新节点的next指向原前驱的下一个节点 paraListPtr-nodes[q].next paraListPtr-nodes[p].next; // 前驱节点的next指向新节点 paraListPtr-nodes[p].next q; } /** * 删除链表中第一个匹配的字符 * param paraListPtr 链表管理器指针 * param paraChar 要删除的字符 */ void deleteElement(ListPtr paraListPtr, char paraChar) { int p, q; p 0; // 从头结点开始 // 步骤1查找待删除节点的前驱 // 条件1未到达链表末尾 // 条件2下一个节点的数据不等于要删除的字符 while ((paraListPtr-nodes[p].next ! -1) (paraListPtr-nodes[paraListPtr-nodes[p].next].data ! paraChar)) { p paraListPtr-nodes[p].next; // 继续向后移动 } // 步骤2判断是否找到 if (paraListPtr-nodes[p].next -1) { printf(Cannot delete %c\n, paraChar); // 未找到要删除的字符 return; } // 步骤3执行删除操作 q paraListPtr-nodes[p].next; // q为要删除的节点下标 // 前驱节点的next指向被删除节点的下一个节点跳过被删除节点 paraListPtr-nodes[p].next paraListPtr-nodes[q].next; // 标记该位置为空闲模拟内存释放 paraListPtr-used[q] 0; } /** * 输出内存状态信息用于调试 * param paraListPtr 链表管理器指针 */ void outputMemory(ListPtr paraListPtr) { int i; printf(Now output the memory.\n); // 使用%p格式符输出内存地址并强制转换为void*类型 printf(The address of the list: %p\n, (void*)paraListPtr); // 链表管理器地址 printf(The address of nodes: %p\n, (void*)paraListPtr-nodes); // 节点数组地址 printf(The address of used: %p\n, (void*)paraListPtr-used); // used数组地址 printf(The contents the memory: [data, next, used]\n); // 输出每个节点的详细信息 for (i 0; i DEFAULT_SIZE; i) { printf([%c, %d, %d]\n, paraListPtr-nodes[i].data, // 节点的数据 paraListPtr-nodes[i].next, // 下一个节点的下标 paraListPtr-used[i]); // 是否被使用 } } /** * 单元测试演示插入、删除操作 */ void appendInsertDeleteTest() { // 1. 初始化链表 ListPtr tempList initLinkedList(); printList(tempList); // 打印空链表 outputMemory(tempList); // 输出初始内存状态 // 2. 依次插入字符构成Hello insertElement(tempList, H, 0); insertElement(tempList, e, 1); insertElement(tempList, l, 2); insertElement(tempList, l, 3); insertElement(tempList, o, 4); printList(tempList); // 输出: Hello // 3. 测试删除操作 printf(Deleting e.\n); deleteElement(tempList, e); // 删除e printf(Deleting a.\n); deleteElement(tempList, a); // 尝试删除不存在的a printf(Deleting o.\n); deleteElement(tempList, o); // 删除o printList(tempList); // 输出删除后的结果 // 4. 在位置2插入x insertElement(tempList, x, 2); printList(tempList); // 输出最终结果 // 5. 输出最终内存状态 outputMemory(tempList); // 6. 释放内存 freeLinkedList(tempList); } /** * 主函数程序入口 */ int main() { appendInsertDeleteTest(); // 运行单元测试 return 0; }

相关文章:

【静态链表】

#include <stdio.h> #include <stdlib.h> #define DEFAULT_SIZE 5 // 静态链表的容量&#xff08;包括头结点&#xff09;/*** 静态链表节点结构* 使用数组下标代替指针来实现链式存储*/ typedef struct StaticLinkedNode {char data; // 存储的字符数据int ne…...

如何在5分钟内掌握UnityExplorer:游戏运行时调试的终极指南

如何在5分钟内掌握UnityExplorer&#xff1a;游戏运行时调试的终极指南 【免费下载链接】UnityExplorer An in-game UI for exploring, debugging and modifying IL2CPP and Mono Unity games. 项目地址: https://gitcode.com/gh_mirrors/un/UnityExplorer 想要在游戏运…...

Windows热键侦探:3分钟快速定位快捷键冲突的终极指南

Windows热键侦探&#xff1a;3分钟快速定位快捷键冲突的终极指南 【免费下载链接】hotkey-detective A small program for investigating stolen key combinations under Windows 7 and later. 项目地址: https://gitcode.com/gh_mirrors/ho/hotkey-detective 你是否曾遇…...

Adobe Illustrator批量替换脚本:告别手动操作,10倍提升设计效率的终极解决方案

Adobe Illustrator批量替换脚本&#xff1a;告别手动操作&#xff0c;10倍提升设计效率的终极解决方案 【免费下载链接】illustrator-scripts Adobe Illustrator scripts 项目地址: https://gitcode.com/gh_mirrors/il/illustrator-scripts 还在为Adobe Illustrator中重…...

Windows下保姆级教程:用TensorRT 8.6.1加速你的YOLOv8模型(从.pt到.trt)

Windows平台YOLOv8模型加速实战&#xff1a;TensorRT 8.6.1全流程解析 在计算机视觉领域&#xff0c;YOLOv8凭借其卓越的检测精度和速度成为工业界的热门选择。然而&#xff0c;当我们需要将训练好的模型部署到实际生产环境时&#xff0c;如何充分发挥硬件性能成为关键挑战。本…...

从毫米波到Sub-6G:实测对比不同5G频段下,波束管理策略的实战差异与优化要点

毫米波与Sub-6G频段下的5G波束管理实战指南&#xff1a;从原理到参数调优 当我们在东京银座的十字路口测试毫米波基站时&#xff0c;一个有趣的现象出现了&#xff1a;用户设备在移动过程中频繁触发波束恢复流程&#xff0c;而同一位置的Sub-6G设备却保持稳定连接。这个现象揭示…...

别再用SMB传大文件了!Windows 11 22H2下,试试Robocopy这个命令,速度直接拉满

Windows 11大文件传输终极提速方案&#xff1a;Robocopy实战指南 你是否经历过在局域网内传输几十GB的视频素材或游戏安装包时&#xff0c;进度条像蜗牛爬行般的绝望&#xff1f;特别是在升级到Windows 11 22H2后&#xff0c;许多用户发现文件传输速度出现了明显下降。这并非你…...

使用 Taotoken 后 API 调用延迟与稳定性体验观察

使用 Taotoken 后 API 调用延迟与稳定性体验观察 1. 接入与初步测试体验 在将现有的大模型调用链路迁移到 Taotoken 平台后&#xff0c;最直接的感受是接入过程的平滑性。由于 Taotoken 提供了 OpenAI 兼容的 API 接口&#xff0c;原有代码几乎无需修改&#xff0c;只需将 ba…...

从LSTM的门控到Transformer的FFN:聊聊Sigmoid、Tanh、ReLU在真实模型里的‘工作岗位’

从LSTM的门控到Transformer的FFN&#xff1a;聊聊Sigmoid、Tanh、ReLU在真实模型里的‘工作岗位’ 在深度学习的架构设计中&#xff0c;激活函数的选择远非简单的数学特性对比。当我们翻开LSTM的论文或Transformer的源码&#xff0c;会发现Sigmoid、Tanh和ReLU这些函数被精心安…...

2026年护理学论文降AI工具推荐:护理研究和临床实践部分降AI方案

2026年护理学论文降AI工具推荐&#xff1a;护理研究和临床实践部分降AI方案 直接给结论&#xff1a;嘎嘎降AI&#xff08;www.aigcleaner.com&#xff09;&#xff0c;4.8元&#xff0c;知网AI率58%降到5.9%&#xff0c;稳定可靠。 护理学论文降AI工具怎么选、怎么用&#xf…...

别再硬编码了!Transformers Trainer的compute_metrics如何优雅传入额外数据(label_names参数详解)

Transformers Trainer进阶指南&#xff1a;如何高效传递自定义数据至评估函数 在自然语言处理的实际工程中&#xff0c;我们常常会遇到标准评估流程无法满足需求的场景。想象一下&#xff0c;当你需要根据样本ID追踪错误预测、需要原始文本来计算领域特定指标&#xff0c;或是需…...

激光雕刻新纪元:用LaserGRBL开启您的创意制造之旅

激光雕刻新纪元&#xff1a;用LaserGRBL开启您的创意制造之旅 【免费下载链接】LaserGRBL Laser optimized GUI for GRBL 项目地址: https://gitcode.com/gh_mirrors/la/LaserGRBL 想象一下&#xff0c;您刚刚完成了一个精美的设计&#xff0c;想要将它永久地雕刻在木头…...

终极指南:如何用Sunshine自建游戏串流服务器,让低配设备畅玩3A大作

终极指南&#xff1a;如何用Sunshine自建游戏串流服务器&#xff0c;让低配设备畅玩3A大作 【免费下载链接】Sunshine Self-hosted game stream host for Moonlight. 项目地址: https://gitcode.com/GitHub_Trending/su/Sunshine Sunshine是一款强大的开源游戏串流服务器…...

如何快速使用Spyder:Python科学计算开发环境终极指南

如何快速使用Spyder&#xff1a;Python科学计算开发环境终极指南 【免费下载链接】spyder Official repository for Spyder - The Scientific Python Development Environment 项目地址: https://gitcode.com/gh_mirrors/sp/spyder Spyder是专为科学计算和数据分析设计的…...

Bandizip下载 v8.00 官网免费版 专业的电脑文件解压缩软件

Bandizip是一款电脑上的解压缩软件。借助它&#xff0c;你可以快速压缩各种文件&#xff0c;或者解压各种格式的压缩包&#xff0c;其功能效果类似于WinRAR、7-Zip等软件。它最大的特点&#xff0c;就是界面更加美观&#xff0c;非常现代化&#xff0c;也很简洁。 软件支持压缩…...

从‘手’到‘眼’的坐标系迷宫:一文讲透线激光手眼标定里的欧拉角、四元数与旋转矩阵(避坑指南)

从‘手’到‘眼’的坐标系迷宫&#xff1a;一文讲透线激光手眼标定里的欧拉角、四元数与旋转矩阵&#xff08;避坑指南&#xff09; 在工业机器人与视觉传感器的协同作业中&#xff0c;手眼标定是确保精准操作的关键环节。想象一下&#xff0c;当机械臂需要根据激光传感器捕捉的…...

保姆级教程:用SDK Manager给Jetson Orin NX/Xavier NX/Nano刷Ubuntu系统镜像(含短接操作详解)

从零开始&#xff1a;Jetson开发板系统刷写全流程实战指南 开篇&#xff1a;为什么需要这份指南&#xff1f; 第一次拿到Jetson开发板时的兴奋&#xff0c;很快就会被"如何正确安装系统"的困惑所取代。不同于普通电脑的即插即用&#xff0c;嵌入式开发板的初始化需要…...

3步解锁锐龙处理器隐藏性能:RyzenAdj电源管理工具完全指南

3步解锁锐龙处理器隐藏性能&#xff1a;RyzenAdj电源管理工具完全指南 【免费下载链接】RyzenAdj Adjust power management settings for Ryzen APUs 项目地址: https://gitcode.com/gh_mirrors/ry/RyzenAdj 你是否觉得自己的AMD锐龙笔记本电脑续航时间太短&#xff1f;…...

维修工程师必备:手把手教你用AD-HP530ICE仿真器读取ADI BF533 DSP程序(附驱动加载避坑指南)

维修工程师实战&#xff1a;ADI BF533 DSP程序读取全流程与深度避坑指南 当一块搭载ADI Blackfin处理器的工控板因DSP芯片损坏需要更换时&#xff0c;许多维修工程师都会遇到这样的困境&#xff1a;新换的空白芯片无法使设备恢复正常工作。这背后往往是因为原DSP中存储的关键程…...

ESP32玩转ST7735屏:除了显示中文,如何用urequests获取天气并展示?

ESP32联网天气站&#xff1a;用ST7735屏打造动态气象信息中心 当ESP32遇上ST7735屏幕&#xff0c;简单的文字显示已经不能满足开发者的探索欲望。今天&#xff0c;我们将突破静态显示的局限&#xff0c;打造一个能实时获取并展示天气信息的智能终端。这不仅仅是技术的堆砌&…...

Fernflower Java反编译器深度解析:揭秘字节码逆向工程的终极指南

Fernflower Java反编译器深度解析&#xff1a;揭秘字节码逆向工程的终极指南 【免费下载链接】fernflower Decompiler from Java bytecode to Java, used in IntelliJ IDEA. 项目地址: https://gitcode.com/gh_mirrors/fe/fernflower Fernflower是业界公认最强大的Java字…...

告别手动描边!用X-AnyLabeling和SAM模型,10分钟搞定YOLOv8-seg数据集标注

10倍效率革命&#xff1a;X-AnyLabelingSAMYOLOv8-seg智能标注全流程实战 标注效率是计算机视觉项目的第一道门槛。当面对500张工业零件图像需要标注时&#xff0c;传统手动描边可能需要消耗一个工程师整整三天的工作量——而现在&#xff0c;这个时间可以被压缩到3小时以内。这…...

轻松掌握vue3-element-admin字体设置:从基础调整到深度定制全攻略

轻松掌握vue3-element-admin字体设置&#xff1a;从基础调整到深度定制全攻略 【免费下载链接】vue3-element-admin &#x1f525;基于 Vue 3 Vite 7 TypeScript element-plus 构建的后台管理前端模板&#xff08;配套后端源码&#xff09;&#xff0c;vue-element-admin 的 …...

Sa-Token V1.31.0 新拦截器实战:在 RuoYi-Vue-Plus 4.3.0 中如何用 @SaIgnore 替换 @Anonymous 提升性能

Sa-Token V1.31.0 拦截器升级实战&#xff1a;RuoYi-Vue-Plus 4.3.0 性能优化指南 最近在重构一个基于 RuoYi-Vue-Plus 4.3.0 的后台管理系统时&#xff0c;发现接口响应速度随着业务增长逐渐变慢。通过性能分析工具定位到权限校验环节存在优化空间&#xff0c;恰逢 Sa-Token 发…...

【2024 Laravel AI生产环境故障白皮书】:基于172个真实项目日志分析的TOP 5致命报错及Hotfix补丁包

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Laravel 12 AI集成故障的底层归因模型与防御范式演进 Laravel 12 引入了原生异步任务调度、更严格的类型约束及基于 PHP 8.3 的 JIT 兼容性增强&#xff0c;但其与外部 AI 服务&#xff08;如 LLM API…...

将Claude Code编程助手配置为使用Taotoken通道的具体方法

将Claude Code编程助手配置为使用Taotoken通道的具体方法 1. 准备工作 在开始配置之前&#xff0c;请确保您已经拥有有效的Taotoken API Key。该Key可以在Taotoken控制台的API密钥管理页面创建。同时&#xff0c;您需要确定要使用的模型ID&#xff0c;该信息可以在Taotoken模…...

别再只调2D参数了!用Python+face3d库,5分钟搞定3D人脸模型重建(附完整代码)

用Pythonface3d库5分钟实现3D人脸重建&#xff1a;从2D照片到可交互模型的完整指南 当你在社交媒体上看到那些能360度旋转的3D人脸特效时&#xff0c;是否好奇过它们是如何从一张普通照片生成的&#xff1f;传统方法需要昂贵的3D扫描设备&#xff0c;而现在&#xff0c;借助开源…...

Python基础:列表的定义、增删改查核心操作

Python基础&#xff1a;列表的定义、增删改查核心操作&#x1f4da; 本章学习目标&#xff1a;深入理解列表的定义、增删改查核心操作的核心概念与实践方法&#xff0c;掌握关键技术要点&#xff0c;了解实际应用场景与最佳实践。本文属于《Python从入门到精通教程》Python入门…...

Laravel 12 Service Container如何接管LLM调用生命周期?——从Facade绑定到Scoped Provider销毁的11层依赖解析(含CallStack火焰图)

更多请点击&#xff1a; https://intelliparadigm.com 第一章&#xff1a;Laravel 12 Service Container与LLM生命周期融合的范式跃迁 Laravel 12 的服务容器不再仅是依赖注入的静态注册中心&#xff0c;而是演化为具备运行时语义感知能力的智能协调枢纽。其新增的 bindTransi…...

聚芯微冲刺港股:年营收8.5亿 去年募资5亿华为OPPO小米是股东

雷递网 雷建平 4月29日武汉聚芯微电子股份有限公司&#xff08;简称&#xff1a;“聚芯微”&#xff09;日前更新招股书&#xff0c;准备在港交所上市。2025年7月&#xff0c;聚芯微完成D轮融资&#xff0c;共募集投资总额5.1亿元。聚芯微D轮领投方为中国互联网投资基金&#x…...