数据结构-线性表的单链式存储结构图解及C语言实现

概念

链式存储:结点在存储器中的位置是任意的,即逻辑相邻的数据元素在物理上不一定相邻

链式存储结构也称非顺序映像或链式映像

图解

链式存储结构中结点一般有两个部分组成,即数据域(data)和指针域,数据域是用于存放数据的,指针域是用来指向下一结点的地址的,其中头节点指向该链表的首元结点,表示该链表从这开始,尾结点的指针域是空的(NULL),当遇到空的指针域表示该链表到这个结点就已结束。

C语言实现

#include<stdio.h>
#include<stdlib.h>//定义链表结构体
typedef struct link{int data;struct link* next;
}Link;//初始化链表(生成长度4的链表并存放1,2,3,4)
Link* initLink() {Link* head = NULL;		//创建头指针Link* a = (Link*)malloc(sizeof(Link));		//开辟一块内存空间给头结点a->data = NULL;a->next = NULL;head = a;		//头指针指向头结点for (int i = 1; i < 5; i++) {				//循环创建链表Link* n = (Link*)malloc(sizeof(Link));	//开辟新内存空间给结点n->data = i;n->next = NULL;a->next = n;			//将结点的next指向下一结点a = a->next;			}return head;		//返回链表首地址
}//向链表中插入数据
void insertData(Link* p, int num, int data) {Link* temp = p;for (int i = 1; i < num; i++) {		//判断插入的位置是否有效temp = temp->next;if (temp == NULL) {printf("插入位置无效\n");return;}}Link* n = (Link*)malloc(sizeof(Link));		//创建新结点n->data = data;		//新结点的数据域赋值n->next = temp->next;		//新结点的指针域指向下一结点的地址temp->next = n;			//上一结点的指针域指向新结点
}//向链表中删除数据
int delData(Link* p, int data) {Link* temp = p;Link* del = NULL;int flag = 0;while (temp->next) {if (temp->next->data == data) {flag = 1;break;}temp = temp->next;}if (flag == 0) {return -1;}else {del = temp->next;temp->next = temp->next->next;free(del);return 1;}
}
//打印链表元素
void displayLink(Link* p) {p = p->next;while (p) {printf("%d ", p->data);p = p->next;}printf("\n");
}
int main() {Link *p = initLink();printf("初始化链表为:");displayLink(p);printf("插入元素后的链表为:");insertData(p, 4, 6);	//在链表中的第二个位置插入一个6displayLink(p);printf("删除元素后的链表为:");delData(p, 6);	//删除链表中数据域为2的结点displayLink(p);
} 

由于作者水平有限,如有错误请广大读者批评指正!

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

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

相关文章

振弦式轴力计 轴向力仪器钢支撑轴力计 清易让选择不再迷路

产品概述 振弦式轴力计是一种用于测量轴向力的仪器。它通过测量振弦的频率变化来计算轴向力的大小。当轴向力作用在弹性元件上时&#xff0c;振弦的张力会发生变化&#xff0c;从而导致振弦的频率发生变化。电磁线圈用于驱动振弦并测量其频率。信号处理单元则用于将频率信号转…

Anthropic谋求新一轮融资 估值或达400亿美元

&#x1f989; AI新闻 &#x1f680; Anthropic谋求新一轮融资 估值或达400亿美元 摘要&#xff1a;美国AI初创公司Anthropic正在与投资者洽谈新一轮融资&#xff0c;估值可能达到300至400亿美元&#xff0c;约为今年初融资估值的两倍。Anthropic依靠其生成式AI聊天机器人Cla…

LNK2019:无法解析的外部符号 “class std::basic_ostream ...(template 的声明)

文章目录 一、问题&#xff1a;二、解决&#xff1a;1. 问题2. 解释① 类模板② 函数模板 一、问题&#xff1a; 今天在实现 vector 时&#xff0c;发现出现了一个错误&#xff1a; 它说&#xff0c;不认识 ostream&#xff0c;我在重载<< 符号时&#xff0c;使用了 ost…

7.ChatGPT与SEO - 优化内容策略【7/10】

引言 在当今的数字化时代&#xff0c;搜索引擎优化&#xff08;SEO&#xff09;已成为数字营销中不可或缺的一部分。它不仅帮助企业提高在线可见性&#xff0c;还直接影响着网站的流量、品牌知名度和最终的销售转化。SEO通过优化网站内容和结构&#xff0c;使其在搜索引擎结果…

【Python】多个dataframe存入excel的不同的sheet表里,而不会被覆盖的方法

我发现&#xff0c;我原来用的多个工作簿存入的方法&#xff0c;发现不太可行了。当使用for循环的时候&#xff0c;原来的sheet 会被新的表给覆盖&#xff0c;后来我找到一种新的方法&#xff1a; with pd.ExcelWriter(file_name ) as writer:Table.to_excel(writer, sheet_na…

JAVA无缝沟通全球国际版多语言语聊系统小程序源码

无缝沟通全球 —— 国际版多语言语聊系统 &#x1f30d;【开篇&#xff1a;跨越语言障碍&#xff0c;与世界无缝对话】&#x1f30d; 在这个全球化的时代&#xff0c;你是否渴望与世界各地的朋友无缝交流&#xff0c;却常常被语言的隔阂所困扰&#xff1f;别担心&#xff0c;今…

振弦式渗压计智慧水利工程 适用恶劣环境有保障

产品概述 振弦式渗压计适合埋设在水工建筑物和基岩内&#xff0c;或安装在测压管、钻孔、堤坝、管道或压力容器中&#xff0c;以测量孔隙水压力或液位。主要部件均采用特殊钢材制造&#xff0c;适合在各种恶劣环境中使用。特殊的稳定补偿技术使传感器具有极小的温度补偿系数。…

Adobe Photoshop 2024 v25.12 (macOS, Windows) 发布下载 - 照片和设计软件

Adobe Photoshop 2024 v25.12 (macOS, Windows) - 照片和设计软件 Acrobat、After Effects、Animate、Audition、Bridge、Character Animator、Dimension、Dreamweaver、Illustrator、InCopy、InDesign、Lightroom Classic、Media Encoder、Photoshop、Premiere Pro、Adobe XD…

CSS02-字体属性、文本属性

一、字体属性 CSS Fonts(字体)属性用于定义字体系列、大小、粗细、和文字样式(如斜体)。 1-1、font-family属性 当font-family有多个值的时候&#xff0c;代码会依次查找当前系统中存在哪种字体&#xff0c;有则使用&#xff0c;没有则查找下一个字体。 1-2、font-size属性 1-3…

wpf中如何访问控件和生成使用事件?

实际上对于初次使用wpf的同学来说&#xff0c;尤其是有winform编程经验的童鞋来说&#xff0c;最需要解决的就是快速掌握访问控件的方法以及生成和使用事件。这样才能让页面具有最起码的交互性。下面我们来分别讲述。 文章原出处&#xff1a;https://blog.csdn.net/haigear/ar…

双链表和循环链表的各种基本运算的算法(数据结构作业03)

双链表 目的&#xff1a;双链表的存储结构和掌握双链表中各种基本运算算法的设计 内容&#xff1a;编写一个程序dlinkst.cpp,实现双链表的各种基本运算和整体建表算法&#xff0c;双链表的元素类型Elem Type为int并在此基础上设计一个程序。 (1)初始化双链表h。 (2)依次采用尾…

电动车无钥匙一键启动‌系统应用

电动车无钥匙一键启动‌是一种便捷的启动方式&#xff0c;它允许车主在不使用传统钥匙的情况下启动车辆。这种启动方式通常依赖于无线射频识别&#xff08;RFID&#xff09;技术&#xff0c;通过车主随身携带的智能卡里的芯片感应自动开关门锁。当车主走近车辆时&#xff0c;门…

日志系统扩展一:日志落地数据库:MySQL、SQLite3

日志系统扩展一&#xff1a;日志落地数据库&#xff1a;MySQL、SQLite3 一、设计1.怎么落地2.落地的具体设计3.表的设计1.MySQL2.SQLite3 二、数据库访问Helper的实现1.需要事务&#xff0c;但是无需回滚&#xff0c;如何理解&#xff1f;1.需要事务2.无需回滚 2.SqliteHelper1…

ICM20948 DMP代码详解(40)

接前一篇文章&#xff1a;ICM20948 DMP代码详解&#xff08;39&#xff09; 上一回继续解析inv_icm20948_set_slave_compass_id函数&#xff0c;解析到第5段代码inv_icm20948_setup_compass_akm函数&#xff0c;本回解析接下来的代码。为了便于理解和回顾&#xff0c;再次贴出该…

77、Python之函数式编程:一文搞懂functools模块的核心应用

引言 Python作为一种支持多范式的编程语言&#xff0c;除了在“一切皆对象”的理念支持下的&#xff0c;函数对象也是一等公民、各种高阶函数的自然实现、lambda表达式快速编写纯函数之外。还有一个内置的模块functools&#xff0c;能够更好地支持我们在Python中应用函数式编程…

企业职工薪资查询系统小程序的设计

管理员账户功能包括&#xff1a;系统首页&#xff0c;个人中心&#xff0c;员工管理&#xff0c;部门管理&#xff0c;工资信息管理&#xff0c;工资安排管理&#xff0c;考勤信息管理&#xff0c;交流论坛&#xff0c;系统管理 微信端账号功能包括&#xff1a;系统首页&#…

LTE协议栈学习

1、高通Modem架构 LTE网络架构 3、LTE协议栈 1、 NAS协议栈: EPS Mobility Management (EMM) 支持UE中的移动功能 EPS Session Management (ESM) 支持在UE和PDN网关之间建立和维护IP连接 高通平台NAS层结构 根据3GPP TS 23.122描述&#xff0c; 自动搜网顺序如下 HPLMN EH…

数据结构之线性表——LeetCode:67. 二进制求和,27. 移除元素,26. 删除有序数组中的重复项

67. 二进制求和 题目描述 67. 二进制求和 给你两个二进制字符串 a 和 b &#xff0c;以二进制字符串的形式返回它们的和。 运行代码&#xff08;javaC) class Solution {public String addBinary(String a, String b) {StringBuilder ansnew StringBuilder();int ca0;for(i…

四川财谷通信息技术有限公司与抖音小店的深度合作

在数字经济蓬勃发展的今天&#xff0c;电商平台已成为推动社会经济增长的重要引擎。其中&#xff0c;抖音小店作为短视频与电商深度融合的产物&#xff0c;凭借其庞大的用户基础、精准的流量分发机制以及创新的购物体验&#xff0c;迅速崛起为电商领域的一股不可忽视的力量。而…

CSS的表格属性

border属性 规定CSS表格边框。 table,td{border: 1px solid green;/*1px表示设置边框的大小&#xff0c;solid表示边框为实线&#xff0c;green表示边框的颜*/} border-collpapse属性 设置表格的边框是否被折叠成一个单一的边框或隔开。 table{border-collapse: collapse;} wi…