一.ListMe接口: import java.util.ArrayList; //实现线性表(顺序表和链表)的接口://提供add get isEmpty size 功能public interface ListMe<E> { //返回线性表大小:线性表元素个数,非底层数组长度 public int size(); //添加元素,追加在线性表最后 public void add(E e); //(方法重载)添加元素,追加在线性表的index下标位置(插入) public void add(E…
线性表的本质: 1.线性表(List)是零个或者多个数据元素的集合: 2.线性表中的数据元素之间是有顺序的: 3.线性表中的数据元素个数是有限的: 4.线性表中的数据元素的类型必须相同: 定义: 线性表是具有相同类型的n(>=0)个数据元素的有限序列 (a1,a2,a3.....) a1是表项,n是表长度 性质: 1.a0为线性表的第一个元素,只有一个后继 2.an为线性表的最后一个元素,只有一个前驱 3.除了a0,an外的其它元素ai,既有前驱,又有后继 4.线性表能够逐项访问和顺序存取 总结…
之前总结过使用C语言描述的顺序表数据结构.在C语言类库中没有为我们提供顺序表的数据结构,因此我们需要自己手写,详细的有关顺序表的数据结构描述和C语言代码请见[我的这篇文章]. 在Java语言的JDK中,为我们提供了专门的顺序表的数据结构API—— ArrayList . Java中的ArrayList的基本存储思路和C语言中的思路相似,即将所有元素存储在一个数组中,当数组中的元素个数达到某种标准时,就要扩容.由于顺序表中的其他操作在Java和C中的实现方式大同小异,因此,本文不再详细介绍这些操作…
线性表的顺序存储结构.也称为顺序表.指用一段连续的存储单元依次存储线性表中的数据元素. 依据顺序表的特性,我们用数组来实现顺序表,以下是我通过数组实现的Java版本号的顺序表. package com.phn.datestructure; /** * @author 潘海南 * @Email 1016593477@qq.com * @TODO 顺序表 * @date 2015年7月16日 */ public class FOArrayList<E> { // 顺序表长度 private int…
什么是顺序表 顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构. 在使用顺序表存储数据前,会先申请一段连续的内存空间(即数组),然后把数组依次存入内存,中间没有一点空隙. 基本操作 每个数据结构都有集合对数据处理的方法,这能让我们更方便的使用保存在数据结构中的数据.顺序表的基本操作有:增(add),删(remove),改(set),查(find),插(insert)等. 在这里我们只详细讲解remove 和 insert 操作,其他实现可看下…
5.java实现方式: 5.1.顺序表的抽象结构 package com.xgp.顺序表; public interface MyList<T> { //1. initList(&L):初始化表.构造一个空的线性表.放回值应该是一个线性表 MyList<T> initList(); //2. destroyList(&L):销毁操作.销毁线性表,并释放线性表L所占的内存空间.放回值为void boolean destroyList(); //3. locateEle…
顺序表是线性表的一种,它将元素存储在一段连续的内存空间中,表中的任意元素都可以通过下标快速的获取到,因此,顺序表适合查询操作频繁的场景,而不适合增删操作频繁的场景. 下面是使用 C语言 编写的顺序表的代码: 顺序表的头文件SeqList.h中的代码如下: /** * 顺序表(线性存储) * 注意:添加数据时,先判断容量是否存满,存满才扩容,而不是添加元素后判断扩容! */ #include <stdio.h> #include <stdlib.h> // 定义常量 #define…
/** * 顺序表,重点是数组动态扩容,插入 * 底层采用数组,长度可以动态变化,此处采用增长一倍 *  java.util.ArrayList每次增长50% *  int newCapacity = oldCapacity + (oldCapacity >> 1); * */public class ArrayList implements List{     private Object[] elementData;//底层数组,目前还没有确定长度     private int size…
//SequentialList.h 顺序表模板类 #ifndef SEQUENTIAL_LIST_HXX#define SEQUENTIAL_LIST_HXX using std::cout; using std::endl; const int MaxSize=100; //顺序表数组最大值 template<class T>class SeqList //定义模板类SeqList(顺序表){ public: SeqList() { length=0; } //无参构造函数,建立一个空的顺…
顺序表是数据结构中最基本也是应用相当广泛的一种数据结构类型.它通常包含三个私有成分,即指向数据数组的头指针.当前表长以及表的实际容量.表的头指针通常指向数据数组的基地址,通过数组的形式进行访问数据数组中的每个元素.其基本结构类型如下图所示: 从上图可以看到,其基本结构包含一个指向数据数组的头指针,当前表长为5,但是该顺序表实际表的容量有7. 下面附上实现该数据结构的各项操作代码 在C.h文件中存放可能要用到的C++库: #ifndef _C_H_ #define _C_H_ #include<i…