1、单链表:线性表的链式存储。

1)特点:用一组任意的存储单元存储数据元素(存储单元可以连续,也可以不连续),逻辑上相邻的元素存储位置不一定相邻。

2)结点包括两个域:数据域(存储数据元素信息)、指针域(存储直接后继存储位置)

3)指针或链:指针域中存储的信息。

2、头指针:链表中第一个结点的存储位置,整个链表的存取必须从头指针开始。

3、头结点:在单链表的第一个结点前附设一个结点,其数据域可不存储信息,可存储附加信息。若指针域为空,则线性表为空表。

引入头结点的优点:

1)使得在链表的第一个位置上的操作和在表的其他位置上的操作一致。

2)空表和非空表的处理一致。

4、单链表的结点类型

typedef struct LNode {
 int data;
 struct LNode * next;
}LNode,* Linklist;

5、 单链表
 LNode * s, *p, *q;
 Linklist L;
 int i, temp;
 1)插入结点的代码片段,时间复杂度为O(n)。
 p = GetElem(L, i - 1);
 s->next = p->next;
 p->next = s;
 2)将* s结点插入到* p之前的代码片段,时间复杂度为O(1)。
 s->next = p->next;
 p->next = s;
 temp = p->data;
 p->data = s->data;
 s->data = temp;
 3)删除结点的代码片段,,时间复杂度为O(n)。
 p = GetElem(L, i - 1);
 q = p->next;
 p->next = q->next;
 free(q);
 4)删除结点* p,时间复杂度为O(1)。
 q = p->next;
 p->data = p->next->data;
 p->next = q->next;
 free(q);

6、采用头插法建立单链表,从表尾到表头逆向建立单链表L,每次均在头结点之后插入元素,时间复杂度为O(n)。
Linklist list_headinsert(Linklist &L)
{
 LNode * s;
 int x;
 L = (Linklist)malloc(sizeof(LNode));
 L->data = NULL;
 scanf("%d", &x);
 while (x!=9999)
 {
  s = (LNode *)malloc(sizeof(LNode));
  s->data = x;
  s->next = L->next;
  L->next = s;
  scanf("%d", &x);
 }
 return L;
}
7、采用尾插法建立单链表,从表尾到表头正向建立单链表L,每次均在表尾插入元素,时间复杂度为O(n)。
Linklist List_tailinsert(Linklist &L)
{
 int x;
 L = (Linklist)malloc(sizeof(LNode));
 LNode * s, *r = L;//r为表尾指针。
 scanf("%d", &x);
 while (x!=9999)
 {
  s = (LNode *)malloc(sizeof(LNode));
  s->data = x;
  r->next = s;
  r = s;
  scanf("%d", &x);
 }
 r->next = NULL;
 return L;
}
8、按序号查找结点的值,取出单链表L中第i个位置的结点指针,时间复杂度为O(n)。
LNode * GetElem(Linklist L, int i)
{
 int j = 1;
 LNode * p = L->next;
 if (i == 0)
 {
  return L;
 }
 if (i < 1)
 {
  return NULL;
 }
 while (p&&j<i)
 {
  p = p->next;
  j++;
 }
 return p;
}
9、按值查找表结点,查找单链表L中数据域值等于e的结点指针,时间复杂度为O(n)。
LNode * LocateElem(Linklist L, int e)
{
 LNode *p = L->next;
 while (p!=NULL&&p->data!=e)
 {
  p = p->next;
 }
 return p;
}

10、求表长,时间复杂度为O(n)。
int listlength(LNode * p)
{
 int len = 0;
 while (p->next != NULL)
 {
  len++;
  p = p->next;
 }
 return len;
}

11、循环单链表:表中最后一个结点的指针指向头结点。

1)判空条件:头结点的指针指向头指针。

2)设头指针,对表尾进行操作,时间复杂度为O(n)。

3)设尾指针,对表尾和表头进行操作,时间复杂度为O(1)。

12、双链表结点中含有两个指针域,一个指向前驱结点,一个指向后继结点。

13、双链表结点类型
typedef struct DNode {
 int data;
 struct DNode * prior, * next;
}DNode,* DLinklist;

14、 双链表

DNode * m, *k;
 1)插入操作片段,时间复杂度为O(1)。
 m->next = k->next;
 k->next->prior = m;
 m->prior = k;
 k->next = m;
 2)删除操作片段,时间复杂度为O(1)。
 m->next = k->next;
 k->next->prior = m;
 free(k);

15、静态链表:借助数组来描述线性表的链式存储结构。其中指针是结点的相对地址(数组下标),又称游标。

16、静态链表的结构类型

#define maxsize 50
typedef struct {
 int data;
 int next;
}slinklist[maxsize];

数据结构(C语言版)---线性表链式存储表示的更多相关文章

  1. 线性表链式存储设计与实现 - API实现

    基本概念 链式存储定义 为了表示每个数据元素与其直接后继元素之间的逻辑关系,每个元素除了存储本身的信息外,还需要存储指示其直接后继的信息. 表头结点 链表中的第一个结点,包含指向第一个数据元素的指针以 ...

  2. guoshiyv 数据结构与算法2-1 线性链式存储

    线性链式存储:   包含两部分:1.存储的单个元素 2.指针,指向下一个的地址 typedef struct() { ElementType Data; struct Node *Next; }Lis ...

  3. 【C语言--数据结构】线性表链式存储结构

    直接贴代码 头文件 #ifndef __LINKLIST_H__ #define __LINKLIST_H__ typedef void LinkList; typedef struct _tag_L ...

  4. 线性表链式存储方式的C语言实现

    /* 编译器:Dev-c++ 5.1.0 文件名:linkList3.cpp 代码版本号:1.0 时间:2015年9月24日11:34:16 */ #include <stdio.h> # ...

  5. 02线性表链式存储_LinkList--(线性表)

    #include "stdio.h" #include "string.h" #include "ctype.h" #include &qu ...

  6. 数据结构C语言实现系列——线性表(线性表链接存储(单链表))

    #include <stdio.h>#include <stdlib.h>#define NN 12#define MM 20typedef int elemType ;/** ...

  7. 【数据结构(C语言版)系列一】 线性表

    最近开始看数据结构,该系列笔记简单记录总结下所学的知识,更详细的推荐博主StrayedKing的数据结构系列,笔记部分也摘抄了博主总结的比较好的内容. 一些基本概念和术语 数据是对客观事物的符号表示, ...

  8. 数据结构C语言版 有向图的十字链表存储表示和实现

    /*1wangxiaobo@163.com 数据结构C语言版 有向图的十字链表存储表示和实现 P165 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h> ...

  9. c++学习书籍推荐《清华大学计算机系列教材:数据结构(C++语言版)(第3版)》下载

    百度云及其他网盘下载地址:点我 编辑推荐 <清华大学计算机系列教材:数据结构(C++语言版)(第3版)>习题解析涵盖验证型.拓展型.反思型.实践型和研究型习题,总计290余道大题.525道 ...

随机推荐

  1. POJ1144 tarjan+网络中割点与割边的数量

    题目链接:http://poj.org/problem?id=1144 割点与割边的数量我们可以通过tarjan的思想从一个点开始对其余点进行访问.访问的顺序构成一棵dfs树,其中根节点到任何一个结点 ...

  2. [AI开发]零代码公式让你明白神经网络的输入输出

    这篇文章的标题比较奇怪,网上可能很少类似专门介绍神经网络的输入输出相关文章.在我实际工作和学习过程中,发现很有必要对神经网络的输入和输出做一个比较全面地介绍.跟之前博客一样,本篇文章不会出现相关代码或 ...

  3. PHP中$$的应用

    PHP中$表示一个变量的声明,$value='test':表示变量value的值是test. 而$$则好像是C语言中的指针,它指向一个变量值的一个变量. 例如:$$value='a';这句话的意思就是 ...

  4. 单调栈-Maximum Width Ramp

    2020-01-23 19:39:26 问题描述: 问题求解: public int maxWidthRamp(int[] A) { Stack<Integer> stack = new ...

  5. 深度学习vs机器学习 | 这些本质区别你知道多少?

    目录: 数据相关性 硬件依赖性 特征工程 解决问题方法 执行时间 可解释性 一.数据相关性 深度学习与传统机器学习最重要的区别是,随着数据量的增加,其性能也随之提高.当数据很小的时候,深度学习算法并不 ...

  6. Linux下段错误(C语言)

    问题描述:在Linux下编程有时会出现段错误的提醒,出现这种错误有可能是因为以下几种原因 1.数组越界:如果在初始化或者接收输入时内容超过了定义好的数组元素个数时会出现段错误,Linux的数组越界检查 ...

  7. 好记性-烂笔头:controller-接收参数方式及注意事项

    长时间未使用的传参方式很容易遗忘 或 记忆混乱,虽然都很简单 但往往都是一些小细节打败了你. 小编决定要把他们记录下来. 1):@RequestBody 接收参数 及 注意事项 注意事项: @Requ ...

  8. coding++:Spring Boot 全局事务解释及使用(二)

    什么是全局事务: Spring Boot(Spring) 事务是通过 aop(aop相关术语:通知(Advice).连接点(Joinpoint).切入点(Pointcut).切面(Aspect).目标 ...

  9. Java 学习笔记 第一章:Java语言开发环境搭建

    第一章:Java语言开发环境搭建 第二章:常量.变量和数据类型 第三章:数据类型转换.运算符和方法入门 1.Java虚拟机——JVM JVM(Java Virtual Machine ):Java虚拟 ...

  10. USACO07MAR Face The Right Way G 差分

    题目链接 https://www.luogu.com.cn/problem/P2882 分析 这个题来看的话好像有点难下手,不如再去读一遍题 N遍,发现一句话很重要Each time the mach ...