c语言数据结构学习心得——线性表
线性表:具有相同数据类型的n(n>0)个数据元素的有限序列。
主要有顺序存储和链式存储。
顺序存储:
特点:地址连续,随机/存取,顺序存储。
建立:首地址/存储空间大小(数组),表长。
方式:静态和动态。
优点:存储密度大;随机存储:快速存取表中任一位置元素。
缺点:插入删除移动大量元素;对存储空间要求高,会产生存储空间的碎片。
1.插入
bool ListInsert(SqList &L,int i,Elemtype e){
if(i<||i>L.length+1) //判断i范围是否有效
return false;
if(L.length>=MaxSize) //当前存储已满,不能插入
return false;
for(int j=L.length;j>=i;j--) //第i个元素后移
L.data [j]=L.data[j-];
L.data[i-]=e; //第i个元素放入e
L.length++; //链表长度加1
return true;
}
最好的情况:表尾插入 只用加一个数据,时间复杂度为o(1);
最坏的情况:表头插入,所有元素后移一位,时间复杂度为o(n);
平均时间复杂度:o(n)。
2.删除
bool ListDelete(SqList &L,int i,Elemtype &e){
if(i<||i>L.length) //判断i范围是否有效
return false;
e=L.data[i-1]; //将被删元素赋给e
for(int j=i;j<L.length;j++) //第i个后元素前移
L.data [j-]=L.data[j];
L.length--; //链表长度减1
return true;
}
时间复杂度如插入,但是具体要分析。
线性表链式存储
通过一组任意的存储单元来存储线性表中的数据元素。为了建立起数据元素之间的线性关系,对每个链表结点,除了自身信息,还存放了一个指向其后继的指针。
单链表:单个指针
typedef struct LNode{ //定义单链表结点类型
Elemtype data; //数据域
struct LNode *next; //指针域
}LNode,*LinkList;
通常用“头指针”来标识一个单链表,如Linklist L,那么头指针L就代指一个单链表。
单链表第一个结点之前附加一个结点,称为“头结点”。其数据域可不设任何信息,也可记录表长等信息。头结点指针域指向线性表第一个元素结点。
头结点:操作方便:第一元素前插入和删除元素和第一结点操作与其他结点一致;链表无论空或不空,操作也统一。
头指针始终指向链表的第一个结点。
双链表:双指针
typedef struct DNode{ //定义单链表结点类型
Elemtype data; //数据域
struct DNode *prior,*next; //前驱指针和后继指针
}DNode,*DLinkList;
插入:
给插入的前一个元素加辅助指针p,插入元素加辅助指针s
1.s->next=p->next;
2.p->next->prior=s;
3.s->prior=p;
4.p->next=s;;
删除:
删除的前一个元素加一个辅助指针p,删除的指针加一个辅助指针q
1.p->next=q->next;
2.q->next->prior=p;
3.free(q);
循环单链表:
与单链表的区别在于,表中最后一个结点的指针不是NULL,而是改为指向头结点,从而整个链表形成一个环。
从任何一个结点出发都能访问到链表的每一个元素。
1.判断条件:头结点的后继指针是否等于头指针。
2.可对循环单链表不设头指针而仅设尾指针,使效率更高。
循环双链表:区别于双链表是首尾结点构成环。
1.尾结点后继指针指向表头结点,头结点的前驱指针指向尾结点。
2.当为空表时,头结点的prior域和next域都等于L。
静态链表:
借助数组来描述线性表的链式存储结构,结点也有数据域data和指针域next,此指针是结点的相对地址(数值下标),又称游标。
对插入与删除操作与动态链表(动态分配内存的方式)相同,只需修改指针,而不需移动元素。
c语言数据结构学习心得——线性表的更多相关文章
- C语言数据结构——第二章 线性表
二.线性表 2.1-线性表简介 2.1.1-线性表的定义 线性表是由若干个相同特性的数据元素组成的有限序列.若该线性表不包含任何元素,则称为空表,此时长度为0,当线性表不为空时,表中的元素的个数就是线 ...
- c语言数据结构学习心得——查找
顺序查找(线性查找) 主要用于在线性表中的查找 int Search1(int a[],int n,int key){ ;i<=n;i++){ //注意从1开始 if(a[i]==key)ret ...
- c语言数据结构学习心得——队列
队列 只允许在一端进行插入,在另一端进行删除的线性表 队头(Front):允许删除的一端(队首) 队尾(Rear):允许插入的一端 FIFO:先进先出 不要求从数组首位开始存储队列 #define M ...
- c语言数据结构学习心得——栈
栈(Stack) 只允许在一端进行插入或删除操作的线性表 栈顶(Top):栈中允许进行插入和删除操作的那一端: 栈底(Bottom):固定的,不允许进行插入或删除的另一端 1.栈是受限的线性表,所以自 ...
- 基于c语言数据结构+严蔚敏——线性表章节源码,利用Codeblocks编译通过
白天没屌事,那我们就来玩玩线性表的实现吧,快要失业了,没饭吃了咋整哦 题目描述假设利用两个线性表LA和LB分别表示两个集合A和B(即:线性表中的数据元素即为集合中的成员),现要求一个新的集合A=A∪B ...
- c语言数据结构学习心得——图
图G由顶点集V和边集E组成,记为G=(V,E) 图不可为空,一定有顶点集不为空 有向图:有向边(弧)的有限集合 无向图:无向边的有限集合 连通:顶点V到顶点V'有路径 连通分量:无向图中的极大连通子图 ...
- c语言数据结构学习心得——树
树 一对多的树型结构,有且只有一个特定的根结点. 结点的度:结点拥有子树的数量{ 度为0:叶子结点/终端结点. 度不为0:非终端结点/分支结点(除去根结点其它称为内部结点).} 树的度:树中所有结点的 ...
- c语言数据结构学习心得——数据结构基本概念
1.数据>数据元素>数据项 数据的基本单位是数据元素,数据元素的基本单位是数据项 2.运算的定义->针对逻辑结构 集合:同属于一个集合,无其他关系.(数学上的集合) 线性结 ...
- c语言数据结构学习心得——二叉树
二叉树 n(n>=0)个结点的有限集合:(五种形态) 1.或者为空二叉树,n=0: 2.或者由一个根结点和两个互不相交的被称为根的左子树和右子树组成.左子树和右子树又分别是一棵二叉树. 3.每个 ...
随机推荐
- uboot启动正常,加载内核kernel启…
先说现象吧:uboot能够正常启动,不过在kernel启动时却出现起不了的现象,停在这里 Uncompressing Linux.................................... ...
- 【转】Spring事务介绍
1. 事务的特性:ACID 原子性(Atomicity):事务是一个原子操作,由一系列动作组成.事务的原子性确保动作要么全部完成,要么完全不起作用. 一致性(Consistency):一旦事务完成(不 ...
- 用eclipse+svn插件,上传新项目到svn服务器
给定trunk路径,https://svn.ws.125089.com/public/nlp/3434index/IndexByModelSolr/trunk/. 其中自己的web项目名字是Index ...
- codeforce 461DIV2 E题
题意 有n棵树排成一排,每个树上都有c[i]只小鸟,只有站在树下才可以召唤小鸟,在i-th树下召唤k(k<=c[i])只小鸟需要消耗cost[i]*k的法力值,但是每召唤一只小鸟可以将法力值的上 ...
- java方法学习记录
---恢复内容开始--- 方法重载:两个方法有相同的名字,但参数不同,就是方法重载,且不能仅仅依据修饰符或者返回类型的不同来重载方法. 命令行参数的使用 有时候你希望运行一个程序时候再传递给它消息.这 ...
- 数字图像处理实验(15):PROJECT 06-02,Pseudo-Color Image Processing 标签: 图像处理MATLAB 2017-05-27 20:53
实验要求: 上面的实验要求中Objective(实验目的)部分是错误的. 然而在我拿到的大纲中就是这么写的,所以请忽视那部分,其余部分是没有问题的. 本实验是使用伪彩色强调突出我们感兴趣的灰度范围,在 ...
- 用JS实现点击TreeView根节点复选框全选
以下两种方法哪个不报错就用哪个.用法都是在TreeView标签中加入OnClick="",然后引入函数名即可 第一种方法:(摘自:http://www.cnblogs.com/fr ...
- MYSQL优化——索引覆盖
索引覆盖:如果查询的列恰好是索引的一部分,那么查询只需要在索引文件上进行,不需要进行到磁盘中找数据,若果查询得列不是索引的一部分则要到磁盘中找数据. 建表: create table test_ind ...
- Part3_lesson3---ARM伪指令学习
1.ARM机器码 对elf格式的文件进行反汇编可得到相应汇编文件的机器码: arm-linux-objdump -D -S start.elf 机器码的解析,可以参考文件ARM Architectur ...
- Charles常见问题
Charles常见问题汇总 Charles是一款很好用的抓包修改工具,但是如果你不是很熟悉这个工具的话,肯定会遇到各种感觉很莫名其妙的状况,这里就来帮你一一解答下面再说说charles的一些其他常用的 ...