news 2026/4/23 12:47:32

C语言链表的相关操作

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
C语言链表的相关操作

本文实现了一个学生信息管理的单向链表系统。头文件定义了链表结构体(包含学号、姓名、成绩)和基本操作接口。源文件实现了创建/销毁链表、插入/删除/查找节点、判断空链表、获取链表长度等功能,并提供了两种格式的打印函数。测试程序演示了创建链表、添加3个学生节点、查找节点、删除节点及打印链表等操作。系统采用模块化设计,通过函数指针实现灵活的打印方式,内存管理严谨,包含错误处理机制。该链表实现可作为学生信息管理的基础数据结构。

#ifndef_LINKED_LIST_H_#define_LINKED_LIST_H_#defineMAX_NAME_LEN14typedefenumStatus{ERROR,OK,NO=0,YES}Status;typedefstructStu{intstu_id;charname[MAX_NAME_LEN];floatscore;}Stu,Data;typedefstructNode{Data data;structNode*next;}Node,*pNode,*link;//1创建一个链表linkcreate_list();//销毁一个链表voiddestroy_list(link*link);//插入一个节点Statusinsert_node(link link,Stu stu);//查找一个节点pNodefind_node(link link,intstuid);//删除一个节点Statusdelete_node(link link,intstuid);//链表是否为空Statusis_empty(link link);//链表一共有多少个节点intget_link_size(link link);//打印一个信息voidprint_one_stu1(Stu stu);voidprint_one_stu2(Stu stu);voidprint_Node(pNode node,voidprint(Stu stu));voidprint_link(link link,voidprint(Stu stu));#endif
#include"linked_list.h"#include<stdlib.h>#include<string.h>#include<stdio.h>linkcreate_list(){pNode p=(pNode)malloc(sizeof(Node)*1);if(!p){perror("malloc error~!\n");exit(-1);}p->data.stu_id=0;strcpy(p->data.name,"");p->data.score=0.0f;p->next=NULL;returnp;}//[] 1 2 3 4 5voiddestroy_list(link*link){if(*link==NULL){return;}Node*current=*link;while(current!=NULL){Node*tmp=current;current=current->next;free(tmp);}*link=NULL;return;}Statusinsert_node(link link,Stu stu){if(link==NULL){returnERROR;}pNode new_node=(pNode)malloc(sizeof(Node)*1);if(!new_node){perror("malloc error~!\n");exit(-1);}new_node->data=stu;new_node->next=NULL;pNode p=link;while(p->next!=NULL){p=p->next;}p->next=new_node;returnOK;}pNodefind_node(link link,intstuid){if(link==NULL||link->next==NULL){returnNULL;}pNode current=link->next;while(current!=NULL){if(current->data.stu_id==stuid){returncurrent;}current=current->next;}returnNULL;}Statusdelete_node(link link,intstuid){if(link==NULL&&link->next){returnERROR;}pNode current=link;while(current->next!=NULL&&current->next->data.stu_id!=stuid){current=current->next;}if(current->next==NULL){returnERROR;}Node*tmp=current->next;current->next=tmp->next;free(tmp);returnOK;}voidprint_one_stu1(Stu stu){printf("%d\t%s\t%.2f\n",stu.stu_id,stu.name,stu.score);}voidprint_one_stu2(Stu stu){printf("%d\n%s\n%.2f\n",stu.stu_id,stu.name,stu.score);}voidprint_Node(pNode node,voidprint(Stu stu)){print(node->data);}Statusis_empty(link link){if(link==NULL||link->next==NULL)returnOK;returnNO;}intget_link_size(link link){if(link==NULL||link->next==NULL)return0;size_t size=0;pNode current=link->next;while(current){size+=1;current=current->next;}returnsize;}voidprint_link(link link,voidprint(Stu stu)){if(link==NULL||link->next==NULL)return;pNode current=link->next;while(current){print(current->data);current=current->next;}return;}
#include"linked_list.h"#include<stdio.h>#include<stdlib.h>voidtest(){link link=create_list();Stu s1={1001,"libai",99.0f};//shift + alt + 下Stu s2={1002,"libai2",92.0f};Stu s3={1003,"libai3",99.0f};insert_node(link,s1);insert_node(link,s2);insert_node(link,s3);pNode p=find_node(link,1011);if(p)print_Node(p,print_one_stu2);if(p)print_Node(p,print_one_stu1);print_link(link,print_one_stu1);Status status=delete_node(link,1001);printf("%s\n",status?"成功删除":"没找到");print_link(link,print_one_stu1);destroy_list(&link);if(link!=NULL){free(link);link=NULL;}}intmain(){test();return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 23:23:35

无人机遥控器技术要点与算力解析

无人机遥控器的“图&#xff08;高清视频&#xff09;、数&#xff08;遥测数据&#xff09;、控&#xff08;控制指令&#xff09;一体”技术&#xff0c;其核心在于将原本分离的视频传输、数据传输和飞行控制功能深度融合与协同处理。其技术要点、算力需求和运行方式与传统遥…

作者头像 李华
网站建设 2026/4/18 10:43:48

用Guava写出优雅代码!

最近在看一个同学代码的时候&#xff0c;发现代码中大量使用了 Google 开源的 Guava 核心库中的内容&#xff0c;让代码简单清晰了不少&#xff0c;故学习分享出 Guava 中我认为最实用的功能。Guava 项目是 Google 公司开源的 Java 核心库&#xff0c;它主要是包含一些在 Java …

作者头像 李华
网站建设 2026/4/22 7:04:49

【迭代器】js 迭代器与可迭代对象终极详解

目标&#xff1a;不仅会“用”&#xff0c;还能“设计、调试、扩展、优化”。文内包含从零手写、生成器、惰性管道、异步流、资源管理、常见坑、性能建议、练习清单等。1. 核心协议 可迭代协议 (Iterable)&#xff1a;对象实现 obj[Symbol.iterator]()&#xff0c;返回一个迭代…

作者头像 李华
网站建设 2026/4/16 17:40:18

数据库高并发高可用解决方案

一、高可用方案&#xff08;HA, High Availability&#xff09;​​缓存高可用​​&#xff1a;通过双写和双读主备&#xff0c;或利用缓存集群的数据同步与故障自动转移机制实现。​​数据库高可用​​&#xff1a;​​读高可用​​&#xff1a;通过读写分离&#xff08;如MHA…

作者头像 李华
网站建设 2026/4/22 0:41:37

3D打印效率革命:OrcaSlicer深度定制与性能优化实战指南

3D打印效率革命&#xff1a;OrcaSlicer深度定制与性能优化实战指南 【免费下载链接】OrcaSlicer G-code generator for 3D printers (Bambu, Prusa, Voron, VzBot, RatRig, Creality, etc.) 项目地址: https://gitcode.com/GitHub_Trending/orc/OrcaSlicer 你是否曾因切…

作者头像 李华
网站建设 2026/4/23 11:27:18

Peerflix终极评测:颠覆性Node.js流媒体播放神器深度解析

你是否厌倦了漫长的视频下载等待&#xff1f;是否曾因网络缓慢而无法流畅观看高清影片&#xff1f;是否希望在有限的存储空间下享受海量影视资源&#xff1f;Peerflix正是为解决这些痛点而生的革命性工具。这款基于Node.js的流媒体协议客户端通过点对点传输协议实现P2P流媒体传…

作者头像 李华