数据结构(C语言版)---线性表链式存储表示
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语言版)---线性表链式存储表示的更多相关文章
- 线性表链式存储设计与实现 - API实现
基本概念 链式存储定义 为了表示每个数据元素与其直接后继元素之间的逻辑关系,每个元素除了存储本身的信息外,还需要存储指示其直接后继的信息. 表头结点 链表中的第一个结点,包含指向第一个数据元素的指针以 ...
- guoshiyv 数据结构与算法2-1 线性链式存储
线性链式存储: 包含两部分:1.存储的单个元素 2.指针,指向下一个的地址 typedef struct() { ElementType Data; struct Node *Next; }Lis ...
- 【C语言--数据结构】线性表链式存储结构
直接贴代码 头文件 #ifndef __LINKLIST_H__ #define __LINKLIST_H__ typedef void LinkList; typedef struct _tag_L ...
- 线性表链式存储方式的C语言实现
/* 编译器:Dev-c++ 5.1.0 文件名:linkList3.cpp 代码版本号:1.0 时间:2015年9月24日11:34:16 */ #include <stdio.h> # ...
- 02线性表链式存储_LinkList--(线性表)
#include "stdio.h" #include "string.h" #include "ctype.h" #include &qu ...
- 数据结构C语言实现系列——线性表(线性表链接存储(单链表))
#include <stdio.h>#include <stdlib.h>#define NN 12#define MM 20typedef int elemType ;/** ...
- 【数据结构(C语言版)系列一】 线性表
最近开始看数据结构,该系列笔记简单记录总结下所学的知识,更详细的推荐博主StrayedKing的数据结构系列,笔记部分也摘抄了博主总结的比较好的内容. 一些基本概念和术语 数据是对客观事物的符号表示, ...
- 数据结构C语言版 有向图的十字链表存储表示和实现
/*1wangxiaobo@163.com 数据结构C语言版 有向图的十字链表存储表示和实现 P165 编译环境:Dev-C++ 4.9.9.2 */ #include <stdio.h> ...
- c++学习书籍推荐《清华大学计算机系列教材:数据结构(C++语言版)(第3版)》下载
百度云及其他网盘下载地址:点我 编辑推荐 <清华大学计算机系列教材:数据结构(C++语言版)(第3版)>习题解析涵盖验证型.拓展型.反思型.实践型和研究型习题,总计290余道大题.525道 ...
随机推荐
- JavaScript FormData对象,FileReader对象,files属性
一.ajax与FormData的使用 最近在使用ajax朝后端提交数据时,如果提交的数据都是普通键值对还好说,直接使用ajax默认的格式向后端提交即可. $('#d1').click(function ...
- django自动生成接口文档
我们在实际项目中,会需要将我们的一些接口的信息返回给前端,便于前后端的交互,在实际使用中,这种自动生成接口文档的模块很多,我主要是用REST framework自动生成接口文档,这个需要用到的是cor ...
- hdu1072 逃离迷宫系列 bfs
题目链接:http://icpc.njust.edu.cn/Problem/Hdu/1072/ 题意:逃离迷宫,路中可能有炸弹,总时间是6个单位,在有炸弹的位置,如果到达的时刻时间大于0,则恢复到6时 ...
- hdu2642二维树状数组,单点修改+区间查询
题目链接:http://icpc.njust.edu.cn/Problem/Hdu/2642/ 代码如下: #include<bits/stdc++.h> using namespace ...
- 题解 P1002 【过河卒】
正文 简单描述一下题意: 士兵想要过河,他每一次可以往下走一格,也可以往右走一格,但马一步走到的地方是不能走的,问走到\(n\)行,\(m\)列有多少种走法 我们显然应该先根据马的位置将不能走的格子做 ...
- 改变Dataframe的列的数据类型
1.查看DataFrame的数据类型 df.dtypes#查看各列数据类型 df[A].dtypes#查看A列数据类型 2.转换DataFrame的数据类型 df[A].astypes(int)#将A ...
- effective-java学习笔记---注解优于命名模式39
命名模式的缺点有以下三点:(在第 4 版之前,JUnit 测试框架要求其用户通过以 test[Beck04] 开始名称来指定测试方法) 1.拼写错误导致失败,但不会提示. 2.无法确保它们仅用于适当的 ...
- 干货 | NLP算法岗大厂面试经验与路线图分享
最近有好多小伙伴要面经(还有个要买简历的是什么鬼),然鹅真的没有整理面经呀,真的木有时间(。 ́︿ ̀。).不过话说回来,面经有多大用呢?最起码对于NLP岗位的面试来说,作者发现根本不是面经中说的样子 ...
- Hadoop Zookeeper 分布式服务框架
what is Zookeeper? 1,开源的分布式的,为分布式应用提供协调服务的Apache项目2,提供一个简单原语集合,以便于分布式应用可以在它之上构建更高层次的同步服务3,设计非常易于编程,它 ...
- 磅日波浪分析4H 20190927
磅日的短线调整预计在132结束 目前已显现出ABC调整末端. 未来预计开启第五浪升势 破前期反弹高点.