news 2025/12/28 17:40:04

C语言数据结构-链表实现队列详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言数据结构-链表实现队列详解

链表是一种动态数据结构,通过节点间的指针连接实现数据存储。队列是一种先进先出的线性结构,链表实现队列可以避免数组实现时的空间限制问题。

  • 入队:从队尾加入

  • 出队:从队首移除

一、数据结构定义

两个节点:

  • front:总指向第一个节点(出队端)

  • rear:总指向最后一个节点(入队端)

#include <stdio.h> #include <stdlib.h> typedef struct Node { int data; struct Node* next; }Node; //取别名 Node* front = NULL; // 队首指针 Node* rear = NULL; // 队尾指针

二、代码详解

2.1 入队操作(add_queue)

步骤:创建新节点 → 连接队尾 → 更新rear

void add_queue(int value) { // 步骤1:创建新节点 // malloc分配内存,类似:新建一个"盒子" Node* new_node = (Node*)malloc(sizeof(Node)); new_node->data = value; new_node->next = NULL; // 步骤2:判断队列是否为空 if (rear == NULL) { // 队列为空时,新节点既是队首也是队尾 front = new_node; // 队首指向新节点 rear = new_node; // 队尾也指向新节点 } else { // 队列不为空时 rear->next = new_node; // 当前队尾的下一个指向新节点 rear = new_node; // 队尾指针更新为新节点 } }

2.2 出队操作(del_queue)

步骤:保存front → 移动front → 检查是否变空 → 释放内存

int del_queue() { // 步骤1:检查队列是否为空 if (front == NULL) { return -1; // 队列为空 } // 步骤2:保存要删除的节点 Node* temp = front; // temp指向队首 int value = temp->data; // 保存数据 // 步骤3:移动front指针 front = front->next; // front指向下一个节点 // 步骤4:如果出队后队列为空,重置rear if (front == NULL) { rear = NULL; } // 步骤5:释放内存 free(temp); return value; }

2.3 打印队列(print_queue)

void print_queue() { if (front == NULL) { printf("队列为空!\n"); return; } Node* current = front; // 从队首开始 while (current != NULL) { printf("%d ", current->data); current = current->next; // 移动到下一个节点 } printf("\n"); }

2.4 清空队列(clear_queue)

void clear_queue() { while (front != NULL) { del_queue(); } printf("队列已清空!\n"); }

2.4 主函数main

int main() { int a, b, c; a = 10; b = 20; c = 30; printf("=== 链表实现队列测试 ===\n\n"); // 测试入队 printf("1. 测试入队操作:\n"); add_queue(a); add_queue(b); add_queue(c); print_queue(); // 测试获取队首 printf("\n2. 获取队首元素:%d\n", get_front()); // 测试出队 printf("\n3. 测试出队操作:\n"); del_queue(); print_queue(); // 继续入队 printf("\n4. 继续入队:\n"); add_queue(40); add_queue(50); print_queue(); // 出队所有元素 printf("\n5. 出队所有元素:\n"); while (front != NULL) { del_queue(); } print_queue(); // 测试空队列操作 printf("\n6. 测试空队列操作:\n"); del_queue(); // 应该提示队列为空 return 0; }

三、运行结果

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/21 2:35:30

Linly-Talker + LangChain:构建具备记忆的智能数字人助理

Linly-Talker LangChain&#xff1a;构建具备记忆的智能数字人助理 在客户服务、在线教育和虚拟主播日益普及的今天&#xff0c;用户对交互体验的要求早已超越“能说话”这一基本功能。人们期待的是一个能够记住对话历史、理解上下文、带有个性甚至情感反馈的“活生生”的数字…

作者头像 李华
网站建设 2025/12/21 2:33:17

数字人直播新纪元:Linly-Talker助力电商24小时自动带货

数字人直播新纪元&#xff1a;Linly-Talker助力电商24小时自动带货 你有没有注意到&#xff0c;最近在抖音、淘宝的直播间里&#xff0c;有些“主播”从不喝水、不会疲劳&#xff0c;甚至凌晨三点还在激情喊着“三二一上链接”&#xff1f;这些不知疲倦的“人”&#xff0c;很可…

作者头像 李华
网站建设 2025/12/24 6:34:15

Linly-Talker部署教程:GPU环境下快速搭建数字人对话系统

Linly-Talker部署教程&#xff1a;GPU环境下快速搭建数字人对话系统 在虚拟主播、智能客服和AI助手日益普及的今天&#xff0c;如何以低成本构建一个能“听懂”用户提问、“张嘴说话”并具备个性化声音与表情的数字人&#xff0c;已成为企业与开发者关注的核心问题。传统方案依…

作者头像 李华
网站建设 2025/12/21 2:25:11

Linly-Talker在药品使用说明中的逐条强调播放设计

Linly-Talker在药品使用说明中的逐条强调播放设计在医院药房、社区药店甚至家庭场景中&#xff0c;一个反复出现的问题是&#xff1a;患者真的读懂了手中的药品说明书吗&#xff1f;密密麻麻的文字、专业术语的堆叠、警示信息被淹没在段落之间——这些都可能导致用药错误&#…

作者头像 李华
网站建设 2025/12/21 2:23:33

【前端知识点总结】Web身份认证 Cookie vs .Token

在 Web 开发的世界里,身份认证是守护应用大门的第一道锁。长久以来,Cookie 一直是这把锁的忠实守护者。但随着架构的演进,一位新的挑战者——Token——登上了历史舞台,并逐渐成为现代应用的主流选择。 它们之间不是简单的替代关系,而是一场关于设计哲学、安全性和架构演进…

作者头像 李华
网站建设 2025/12/21 2:21:21

当热流遇上代码:COMSOL与Maxwell的工程实践

comsol 热仿真&#xff08;流固耦合散热&#xff09;&#xff0c;Maxwell 2D/3D电场、磁场仿真。工程师的桌面上总有些奇妙的组合——比如左手握着咖啡杯散热&#xff0c;右手在软件里模拟散热。COMSOL的热仿真就像这杯咖啡的温度传递&#xff0c;流固耦合的微妙平衡需要代码来…

作者头像 李华