数据结构简明备忘录 线性表

线性表

线性表是线性结构的抽象,线性结构的特点是结构中的数据元素之间存在一对一的线性关系。

数据元素之间的位置关系是一个接一个的排列:

.除第一个位置的数据元素外,其他数据元素位置的前面都只有一个数据元素。

.除最后一个位置的外,其他数据元素位置的后面都只有一个元素。

线性表通常表示为:L=(D,R)

D是数据元素的有限集合

R是数据元素之间关系的有限集合

线性表的基本操作:

复制代码 代码如下:

public interface IListDS<T> {

int GetLength(); //求长度

void Clear(); //清空

bool IsEmpty(); //判空

void Append(T item); //附加

void Insert(T item, int i); //插入

T Delete(int i); //删除

T GetElement(int i); //取表元素

int Locate(T value); //按值查找

}

顺序表

顺序表是线性表的顺序存储(Sequence Storage),是指在内存中用一块地址连续的空间依次存放线性表的数据元素(Sequence List),具有随机存取的特点。

w: 每个数据元素占w个存储单元

A1:顺序表的基地址(Base Address)

Loc(Ai)=Loc(A1)+(i-1)*w 1<=i<=n

为了理解顺序表,闪电学习了这样一个例题,有兴趣的朋友可以在自己的机器上写一下。

有数据类型为整型的顺序表La和Lb,其数据元素均按从小到大的升序排列,编写一个算法将它们合并成一个表Lc,要求Lc中数据元素也按升序排列。

算法思路:

依次扫描La和Lb的数据元素,比较La和Lb当前数据元素的值,将较小值的数据元素赋给Lc,如此直到一个顺序表被扫描完,然后将未完的那个顺序表中余下的数据元素赋给Lc即可。Lc的容量要能够容纳La和Lb两个表相加的长度。

思路图示:

复制代码 代码如下:

public class SeqList<T> : IListDS<T> {

private int maxsize; //顺序表的容量

private T[] data; //数组,用于存储顺序表中的数据元素

private int last; //指示顺序表最后一个元素的位置

//构造器

public SeqList(int size)

{

data = new T[size];

maxsize = size;

last = -1; //如果顺序表为空,last=-1

}

//索引器

public T this[int index]

{

get { return data[index]; }

set { data[index] = value; }

}

//最后一个元素的位置属性

public int Last

{

get { return last; }

}

//容量属性

public int Maxsize

{

get { return maxsize; }

set { maxsize = value; }

}

//判断顺序表是否为空

public bool IsEmpty()

{

if (last == -1)

return true;

else

return false;

}

//判断顺序表是否为满

public bool IsFull()

{

if (last == maxsize - 1)

return true;

else

return false;

}

//求顺序表的长度

public int GetLength()

{

return last + 1;

}

//清空顺序表

public void Clear()

{

last = -1;

}

//在顺序表末尾添加新元素

public void Append(T item)

{

if (IsFull())

{

Console.WriteLine("List is full.");

return;

}

data[++last] = item;

}

//在顺序表第i个数据元素位置插入一个数据元素

public void Insert(T item, int i)

{

if (IsFull())

return;

if (i < 1 || i > last + 2)

return;

if (i == last + 2)

data[last + 1] = item;

else

{

for (int j = last; j >= i - 1; --j)

{

data[j + 1] = data[j];

}

data[i - 1] = item;

}

++last;

}

//删除顺序表的第i个数据元素

public T Delete(int i)

{

T tmp = default(T);

if (IsEmpty())

return tmp;

if (i < 1 || i > last + 1)

return tmp;

if (i == last + 1)

tmp = data[last--];

else

{

tmp = data[i - 1];

for (int j = i; j <= last; ++j)

data[j] = data[j + 1];

}

--last;

return tmp;

}

//获得顺序表的第i个数据元素

public T GetElement(int i)

{

if (IsEmpty() || (i < 1) || (i > last + 1))

return default(T);

return data[i-1];

}

//在顺序表中查找值为value的数据元素

public int Locate(T value)

{

if (IsEmpty())

return -1;

int i = 0;

for (i = 0; i <= last; ++i)

{

if (value.Equals(data[i]))

break;

}

if (i > last)

return -1;

return i;

}

}

复制代码 代码如下:

public class GenericList

{

public GenericList()

{ }

public SeqList<int> Merge(SeqList<int> La, SeqList<int> Lb)

{

SeqList<int> Lc = new SeqList<int>(La.Maxsize+Lb.Maxsize);

int i = 0;

int j = 0;

int k = 0;

//两个表中元素都不为空

while ((i <= (La.GetLength() - 1)) && (j <= (Lb.GetLength() - 1)))

{

if (La[i] < Lb[j])

Lc.Append(La[i++]);

else

Lc.Append(Lb[j++]);

}

//a表中还有数据元素

while (i <= (La.GetLength() - 1))

Lc.Append(La[i++]);

//b表中还有数据元素

while (j <= (Lb.GetLength() - 1))

Lc.Append(Lb[j++]);

return Lc;

}

}

客户端代码:

复制代码 代码如下:

static void Main(string[] args)

{

SeqList<int> sl1 = new SeqList<int>(4);

sl1.Append(1);

sl1.Append(3);

sl1.Append(4);

sl1.Append(7);

SeqList<int> sl2 = new SeqList<int>(6);

sl2.Append(2);

sl2.Append(5);

sl2.Append(6);

sl2.Append(8);

sl2.Append(11);

sl2.Append(14);

GenericList gl = new GenericList();

SeqList<int> sl3 = gl.Merge(sl1, sl2);

Console.WriteLine("length:" + sl3.GetLength());

for (int i = 0; i < sl3.GetLength(); i++)

{

Console.WriteLine(i + ":" + sl3[i]);

}

}

好了,下一次学习链表。

作者:LevinLee

时间: 2024-10-01 19:38:36

数据结构简明备忘录 线性表的相关文章

数据结构简明备忘录 线性表_MsSql

线性表 线性表是线性结构的抽象,线性结构的特点是结构中的数据元素之间存在一对一的线性关系. 数据元素之间的位置关系是一个接一个的排列: .除第一个位置的数据元素外,其他数据元素位置的前面都只有一个数据元素. .除最后一个位置的外,其他数据元素位置的后面都只有一个元素. 线性表通常表示为:L=(D,R) D是数据元素的有限集合 R是数据元素之间关系的有限集合 线性表的基本操作: 复制代码 代码如下: public interface IListDS<T> { int GetLength(); /

大话数据结构五:线性表的链式存储结构(双向链表)

1. 双向链表:在单链表的每个结点中,再设置一个指向其前驱结点的指针域,那么在双向链表中的结点都有两个指针域,一个指向直接后继,另一个指向直接前驱. 2. 单链表和双向链表比较: 单链表:总是要从头到尾找结点,只能正遍历,不能反遍历. 双向链表: 可以从头找到尾,也可以从尾找到头,即正反遍历都可以,可以有效提高算法的时间性能,但由于每个结点需要记录两份指针,所以在空间占用上略多一点,这就是通过空间来换时间. 3. Java实现双向链表: // 双向链表 public class DoubleLi

大话数据结构四:线性表的链式存储结构(单向循环链表)

1. 单向循环链表:将单链表尾结点的指针端由空指针改为指向头结点,使整个单链表形成一个环,这种头尾相接的单链表称为单向循环链表.   2. 单向循环链表和单链表实现的区别: 1.)添加一个结点到单向循环链表末尾时,必须使其最后一个结点的指针指向表头结点,而不是象单链表那样置为null. 2.)判断是否到达表尾时,单向循环链表可以判断该结点是否指向头结点,单链表只需要知道是否为null.   3.Java实现单向循环链表: // 单向循环链表 public class CircularLinked

大话数据结构二:线性表的链式存储结构(单链表)

1. 线性表的链式存储结构:指的是用一组任意的存储单元存储线性表的数据元素,这组存储单元可以是连续的,也可以是不连续的,这就意味着这些数据元素可以存在内存未被占用的任意位置. 2. 结点:结点由存放数据元素的数据域和存放后继结点地址的指针域组成. 1.)顺序存储结构中,每个数据元素只需要存数据元素的信息就可以了. 2.)链式存储结构中,除了要存储数据元素信息外,还要存储它的后继元素的存储地址. 3.)链表中第一个结点叫头结点,它的存储位置叫做头指针,它的数据域可以不存储任何信息,链表的最后一个结

大话数据结构之三:线性表

1.定义: 线性表表示0个或者多个数据元素的有限序列 线性表的特性有: 除第一个元素外,每一个元素均有一个直接前驱 出最后一个元素外,每一个元素均有一个直接后继 2.线性表抽象数据类型 ADT List  Data          /*线性表的数据对象集合为{a1,a2,...,an},每个元素的类型均为DataType.其中,除第一个元素a1外,   每一个元素有且只有一个直接前驱元素,除了最后一个元素an外,每一个元素有且只有一个直接后继元素.   数据元素直接是一对一的关系.*/  Op

大话数据结构一:线性表的顺序存储结构

1. 线性表的顺序存储结构:指的是用一段地址连续的存储单元依次存储线性表的数据元素. 2. Java实现线性表的顺序存储结构: // 顺序存储结构 public class SequenceList { private static final int DEFAULT_SIZE = 10; // 默认初始化数组大小 private int size; // 当前数组大小 private static Object[] array; public SequenceList() { init(DEF

小菜一步一步学数据结构之(三)线性表的顺序存储结构

线性表的定义和特点 定义: 有n(n≥0)个数据特性相同的元素构成的有序序列称为线性表. 当个数n(n≥0)定于为线性表的长度,n=0时成为空表. 特点: 只有一个首结点和尾结点: 除首尾结点外,其他结点只有一个直接前驱和一个直接后继. 分析26个英文字母组成的英文表(A,B,C,D,-..,Z)数据元素都是字母,元素间关系是线性 抽象数据类型的定义为: ADT List { 数据对象:D={ai|ai∈ElemSet,i1,2,3...n,n≥0} 数据关系:R={<ai-1,ai|ai-1,

大话数据结构三:线性表的链式存储结构(静态链表)

1. 静态链表:用数组描述的链表叫静态链表,通常为方便数据插入,我们会把数组建的大一些. 2. 数组元素(node):由两个数据域组成(data,cursor).数据域data用来存放数据元素,也就是通常我们要处理的数据:而cursor相当于单链表中的指针,存放该元素的后继在数组中的下标. 3. Java实现静态链表: // 静态链表 class StaticLinkedList { private int size; private Node[] node = new Node[100]; /

数据结构教程 第五课 线性表的类型定义

教学目的: 掌握线性表的概念和类型定义 教学重点: 线性表的类型定义 教学难点: 线性表的类型定义 授课内容: 复习:数据结构的种类 线性结构的特点: 在数据元素的非空有限集中, (1)存在唯一的一个被称做"第一个"的数据元素: (2)存在唯一的一个被称做"最后一个"的数据元素: (3)除第一个之外,集合中的每个数据元素均只有一个前驱: (4)除最后一个之外,集合中每个数据元素均只有一个后继. 一.线性表的定义 线性表是最常用且最简单的一种数据结构. 一个线性表是n