Linux-数据结构-线性表-单链表

一.链表的概念

【1】线性表的链式存储

解决顺序存储的缺点,插入和删除,动态存储问题。

【2】特点:

线性表链式存储结构的特点是一组任意的存储单位存储线性表的数据元素,存储单元可以是连续的,也可以不连续。可以被存储在任意内存未被占用的位置上。

所以前面的顺序表只需要存储数据元素信息就可以了。在链式结构中还需要一个元素存储下一个元素的地址。

【3】结构:

为了表示每个数据元素,ai与其直接后继数据元素ai+1之间的逻辑关系,对ai来说,除了存储其本身的信息外,还需要存一个指示器直接后续的信息。把存储元素信息的域叫数据域,把存储直接后继位置的域叫指针域。这两部分信息组成数据元素ai的存储映像,叫结点(Node);

二.链表的常规操作 ADT

单链表中,c语言的描述

typedef struct person {

char name[32];

char sex;

int age;

int score;

}DATATYPE;

typedef struct node {

DATATYPE data;

struct node *next,*prev;

}LinkNode;

typedef struct list {

LinkNode *head;

int tlen;

int clen;

}LinkList;

LinkList *CreateLinkList(int len);

int InsertHeadLinkList(LinkList *list, DATATYPE data);

int ShowLinkList(LinkList *list);

LinkNode *FindLinkList(LinkList *list, char *name);

int DeleteLinkList(LinkList *list, char *name);

int ReviseLinkList(LinkList *list, char *name, DATATYPE data);

int DestroyLinkList(LinkList *list);

int InsertTailLinkList(LinkList *list, DATATYPE data);

三. 顺序表和链表 优缺点

【1】存储方式:

顺序表是一段连续的存储单元

链表是逻辑结构连续物理结构(在内存中的表现形式)不连续

【2】时间性能

查找 顺序表O(1)

链表 O(n)

【3】插入和删除

顺序表 O(n)

链表 O(1)

【4】空间性能

顺序表 需要预先分配空间,大小固定

链表, 不需要预先分配,大小可变,动态分配

四.源码

【1】linklist.h

(1)定义存放数据的结构体,这里data不使用指针的原因是单链表有专门的指针域指向下一个节 点的地址

(2)定义结点包含指针域和数据域

(3)定义头,后来用于存放第一个节点的地址

【2】linklist.c

(1)创建链表头
(2)从头插入数据
1.思维导图
2.代码
(3)打印链表
(4)获取长度
(5)从尾插入
(6)查找
(7)按位置插入
(8)删除
(9)修改
(10)消除
相关推荐
Hhy_110712 小时前
【从零开始学习数据结构 ④】:栈 ——后进先出的艺术
c语言·数据结构·学习·visual studio
海清河晏11112 小时前
数据结构 | 链式队列
开发语言·数据结构·链表
ulias21213 小时前
leetcode热题 - 5
数据结构·算法·leetcode
如何原谅奋力过但无声13 小时前
【灵神高频面试题合集04-05】二分查找
数据结构·python·算法·leetcode
我不是懒洋洋13 小时前
【数据结构】排序算法(直接插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序、计数排序)
c语言·数据结构·c++·经验分享·算法·排序算法
辛苦才能13 小时前
数据结构--排序--插入排序(C语言,重点排序面试和比赛都会考察)
c语言·数据结构·面试
qeen871 天前
【数据结构】建堆的时间复杂度讨论与TOP-K问题
c语言·数据结构·c++·学习·
图码1 天前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
我星期八休息1 天前
IT疑难杂症诊疗室:AI时代工程师Superpowers进化论
linux·开发语言·数据结构·人工智能·python·散列表
漂流瓶jz1 天前
UVA-1152 和为0的4个值 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·二分查找·题解·aoapc·算法竞赛入门经典·uva