栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

数据结构复习之线性表(整理完毕)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

数据结构复习之线性表(整理完毕)

数据结构 线性表(整理完毕) 线性表 一、逻辑结构

线性表示具有相同特性数据元素的有限序列

注意点:
为什么需要用相同特性:方便用统一的方法去处理
有限:但是线性表中的元素可以为0
序列:体现了一对一的逻辑特性(每个元素有则仅有一个前驱和一个后继)

二、存储结构 顺序结构

链式存储结构 单链表

双链表


循环链表


线性表考点 特性对比

在顺序表中 插入和删除元素 可能会导致移动大量元素的连带操作(操作发生在表尾位置例外),而链表不会【选择题可能会考】

顺序表支持随机存取,单链表不支持

从表整体来看,顺序表(必须占用一片连续的存储单元)的存储空间利用率可能比链表低(有些地皮没盖满房子)
从单个来看。顺序表存储空间利用率比链表高【链表还需要一块“地皮”放指针】

元素的移动次数计算

元素的移动次数只针对顺序表


可以自己推一下 删除元素平均要移动的元素个数

静态链表

本来链表都是动态的,但是这里把“指针” 的类型变为int型 表示该元素的下一个位置

插入删除


关键在于 第一步先存 插入元素 的 后继结点

带头结点的链表,其头指针不随操作而改变,可以减少错误

顺序表的插入


p是插入的位置 e是插入的值
位置是【0 ~ maxsize-1】如果length==maxSize说明没位置可以插入了

顺序表的删除


这里为什么不用length==0 因为这个条件已经包含在前面两个条件中了

建表

尾插法建表


每次需要在尾部插入一个结点,所以我们需要一个指针r始终指向尾结点
head =(LNode*)malloc(sizeof(LNode))给head指针申请一个存储空间
写head->next=null 是个好习惯
p指针是接受新结点的指针,r指针始终指向当前尾结点的指针
n 为结点的个
p->next=r->next (中部插入适用)

头插法建表

真题回顾1

不要学我 只看不敲


多看看

逆置(基本算法)

定义两个整形变量,分别指向两端

顺序表

链表

取最值(基础算法) 顺序表中取最小值


一个是存最大值的数,一个是最大值的位置
可以自己思考一下取最小值的代码

链表中取最小值

真题回顾2


二路归并(基础算法) 顺序表归并


传入三个数组a、b 、c,a和b存原始的元素,c存归并后的元素
m,n为a、b的长度

链表归并


A和B的头指针是不需要发生改变的,所以不需要引用型
r是指向新链表的尾部
c=a 其实是把a的头结点拿给了c
free(b)b的头结点释放掉了
因为p q已经指向两个链表的第一个元素了

链表归并与顺序表归并最大的不同在于 最后两个代码语句 只用一个if语句 而不同一个循环 (为啥咧,因为链表后面都是连在一块的)

大家可以思考一下 逆归并的代码

划分

把一堆元素分类的工作
分类规则:以某个元素为标准把线性表中的元素分为左右两边(如左边都小于右边)
三种题型
1.给你一个顺序表,第一个元素为枢轴,把这个线性表分为左右两部分,左边都小于右边


2.给你一个顺序表,还是以第一个元素为枢轴,但是对比的数(comp)不同了。把这个线性表分为左右两部分,左边都小于右边


3.想以线性表中任意一个元素作为枢轴来划分

方法都一样,就是把那个枢轴的元素跟第一个元素交换位置就可以

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/311503.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号