线性表的顺序存储结构。也称为顺序表。指用一段连续的存储单元依次存储线性表中的数据元素。

依据顺序表的特性,我们用数组来实现顺序表,以下是我通过数组实现的Java版本号的顺序表。

package com.phn.datestructure;
/**
* @author 潘海南
* @Email 1016593477@qq.com
* @TODO 顺序表
* @date 2015年7月16日
*/
public class FOArrayList<E> {
// 顺序表长度
private int size;
// 顺序表默认数组为null
private Object[] data = null;
// 顺序表中数组的初始化长度
private int capacity;
// 顺序表默认初始化长度
private static final int DEFUALT_INITIAL_SIZE = 0;
/**
* 默认无參构造函数
*/
public FOArrayList() {
this(DEFUALT_INITIAL_SIZE);
}
/**
* @TODO 带參构造函数
* @param initialSize 初始化顺序表长度
*/
public FOArrayList(int initialSize) {
if (initialSize < 0) {
throw new RuntimeException("数组大小错误:" + initialSize);
}
this.data = new Object[initialSize];
this.capacity = initialSize;
this.setSize();
}
/**
* @TODO 设置顺序表的长度
*/
private void setSize() {
this.size = 0;
}
/**
* @TODO 获取顺序表的长度
* @return size 顺序表的长度
*/
public int size() {
return this.size;
}
/**
* @TODO 顺序表加入元素
* @param e 数据元素类型
* @return true
*/
public boolean add(E e) {
ensureSize(size);
this.data[size] = e;
this.size++;
return true;
}
/**
* @TODO 顺序表插入元素
* @param index 插入位置
* @param e 数据元素类型
* @return true
*/
public boolean insert(int index, E e) {
if (index >= 0 && index <= size) {
ensureSize(size);
E temp = (E) this.data[index - 1];
this.data[index - 1] = e;
this.size++;
for (int i = index; i <= size; i++) {
E temp2 = (E) this.data[i];
this.data[i] = temp;
temp = temp2;
}
} else {
throw new RuntimeException("数组下标错误:" + index);
}
return true;
}
/**
* @TODO 顺序表删除元素
* @param index 将要删除的元素的索引位置
* @return E 删除的元素
*/
public E remove(int index) {
validateIndex(index);
E e = (E) this.data[index];
for (int i = index; i < size - 1; i++) {
this.data[i] = this.data[i + 1];
}
this.size--;
return e;
}
/**
* @TODO 依据元素索引位置获取元素
* @param index 元素的索引位置
* @return E 元素e
*/
public E get(int index) {
validateIndex(index);
return (E) this.data[index];
}
/**
* @TODO 将顺序表中索引位置为i的元素改动为元素e
* @param index 元素的索引位置
* @param e 须要改动成的元素
* @return true 改动成功标志
*/
public boolean set(int index, E e) {
validateIndex(index);
this.data[index] = e;
return true;
}
@Override
public String toString() {
return this.arrayToString(data);
}
/**
* @TODO 获取字符串形式的顺序表中的数组序列
* @param a 顺序表中的数组
* @return String 字符串形式的顺序表中的数组序列
*/
private String arrayToString(Object[] a) {
if (a == null)
return "null";
int iMax = this.size - 1;
if (iMax == -1)
return "[]";
StringBuilder b = new StringBuilder();
b.append('[');
for (int i = 0;; i++) {
b.append(String.valueOf(a[i]));
if (i == iMax)
return b.append(']').toString();
b.append(", ");
}
}
/**
* @TODO 验证所给索引位置是否合法
* @param index 给出的索引位置
*/
private void validateIndex(int index) {
if (index >= this.size || index <= 0) {
throw new RuntimeException("数组下标错误:" + index);
}
}
/**
* @TODO 推断是否须要扩充顺序表容量
* @param currentSize 当前顺序表的大小
*/
private void ensureSize(int currentSize) {
if (currentSize == capacity) {
this.capacity = (this.capacity * 3) / 2 + 1;
Object[] newData = new Object[this.capacity];
for (int i = 0; i < currentSize; i++) {
newData[i] = this.data[i];
}
this.data = newData;
}
}
}

主要注意上述3个私有成员变量。例如以下:

// 顺序表长度
private int size;
// 顺序表中数组的初始化长度
private int capacity;
// 顺序表默认数组为null
private Object[] data = null;

如同凝视解释的那样,size用来表示顺序表的长度。data用来表示数组,而capacity用来表示数组的长度.

相信data应该比較好理解,而相应的两个长度变量相对难理解一些,以下解释一下:

  • size指的是对外界訪问这个顺序表的长度时展示的值,是顺序表中数据元素的个数,随顺序表插入和删除操作而会进行改变;
  • capacity表示的是data数组的长度,实际上也是整个顺序表的容量。在顺序表初始化的时候能够赋值。或者之后能够调用顺序表的扩容来进行改变;
  • size是小于等于capacity的。

这里主要讲讲顺序表的插入和删除:

顺序表的插入演示如图所看到的:



依据图片能够看出插入一个元素后,插入位置之后的元素都须要向后移动一个位置。

删除操作则是插入操作的逆过程,删除位置之后的元素都须要向前移动一个位置。

时间复杂度分析:

  • 在顺序表进行存入,查找和改动时,平均时间复杂度都是O(1);
  • 而在进行插入和删除操作时。最快时为O(1),最慢时为O(n),所以平均时间复杂度为O(n)。

解释:上述的存入和插入有差别,存入表示存储在数组末尾,而插入表示插入在任何位置。

优缺点分析:

长处:

  • 不用为表示表中数据元素之间的逻辑关系而添加额外的存储空间;
  • 能够高速的存取表中任何位置的元素。

    缺点:

  • 插入和删除操作须要移动大量元素;

  • 当线性表的长度变化较大的时候,非常难确定存储空间的容量;
  • easy造成存储空间的“碎片”。

Java数据结构-线性表之顺序表ArrayList的更多相关文章

  1. 数据结构Java实现02----线性表与顺序表

    [声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...

  2. 数据结构Java实现01----线性表与顺序表

    一.线性结构: 如果一个数据元素序列满足: (1)除第一个和最后一个数据元素外,每个数据元素只有一个前驱数据元素和一个后继数据元素: (2)第一个数据元素没有前驱数据元素: (3)最后一个数据元素没有 ...

  3. [C++]数据结构:线性表之顺序表

    1 顺序表 ADT + Status InitList(SeqList &L) 初始化顺序表 + void printList(SeqList L) 遍历顺序表 + int ListLengt ...

  4. [数据结构 - 第3章] 线性表之顺序表(C++实现)

    一.类定义 顺序表类的定义如下: #ifndef SEQLIST_H #define SEQLIST_H typedef int ElemType; /* "ElemType类型根据实际情况 ...

  5. C#线性表之顺序表

    线性表是最简单.最基本.最常用的数据结构.线性表是线性结构的抽象(Abstract), 线性结构的特点是结构中的数据元素之间存在一对一的线性关系. 这种一对一的关系指的是数据元素之间的位置关系,即: ...

  6. [C++]线性链表之顺序表<一>

    顺序表中数据元素的存储地址是其序号的线性函数,只要确定了存储顺序表的起始地址(即 基地址),计算任意一个元素的存储地址的时间是相等的,具有这一特点的存储结构称为[随机存储]. 使用的基本数据结构:数组 ...

  7. c/c++ 线性表之顺序表

    线性表之顺序表 存储在连续的内存空间,和数组一样. 下面的代码,最开始定义了一个能存8个元素的顺序表,当超过8个元素的时候,会再追加开辟空间(函数:reInit). 实现了以下功能: 函数 功能描述 ...

  8. [C++]线性链表之顺序表<二>

    /*   @content 线性链表之顺序表   @date 2017-3-21 1:06   @author Johnny Zen  */ /* 线性表     顺序表     链式表[带头指针/不 ...

  9. python基础下的数据结构与算法之顺序表

    一.什么是顺序表: 线性表的两种基本的实现模型: 1.将表中元素顺序地存放在一大块连续的存储区里,这样实现的表称为顺序表(或连续表).在这种实现中,元素间的顺序关系由它们的存储顺序自然表示. 2.将表 ...

  10. 线性表之顺序表C++实现

    线性表之顺序表 一.头文件:SeqList.h //顺序线性表的头文件 #include<iostream> ; //定义顺序表SeqList的模板类 template<class ...

随机推荐

  1. windows下如何添加、删除和修改静态路由

    1.添加一条路由表 route add 192.168.100.0 mask 255.255.255.248 192.168.1.1 metric 3 if 2 1 2 添加一条路由记录,所有到192 ...

  2. [PWA] Cache JSON Data in a React PWA with Workbox, and Display it while Offline

    We can view the PWA offline because we are caching the static and CDN assets for the app - but the l ...

  3. 7. JPA - Hibernate【从零开始学Spring Boot】

    转载:http://blog.csdn.net/linxingliang/article/details/51636976 在说具体如何在spring boot 使用hibernate前,先抛装引玉些 ...

  4. 内置函数new() 和struct{} 初始化的区别

    一.new() 这是一个用来分配内存的内置函数,它的第一个参数是一个类型,不是一个值,它的返回值是一个指向新分配的 t 类型的零值的指针.在golang的代码定义如下: func new(t Type ...

  5. Intent之对象传递(Parcelable传递对象和对象集合)

    接着上一篇文章,以下我们讨论一下怎样利用Parcelable实现Intent之间对象的传递 一.实现对象传递 首先创建User.java实现Parcelable接口: package org.yayu ...

  6. STL学习笔记(第二章 C++及其标准程序库简介)

    本章重点是介绍与C++标准程序库相关的几个最重要的语言新特性 template(模板) 程序库中几乎所有东西都被设计成template形式.所谓templates,是针对“一个或多个尚未明确的型别”所 ...

  7. 51单片机 | 使用D/A转换器实现三角波发生器

    ———————————————————————————————————————————— D/A转换器 CS=0.ILE=1时,WR1信号有效时将数据总线上的信号写入8位输入锁存器 XFER=0时,W ...

  8. 【SpringMVC学习03】SpringMVC中注解和非注解方式下的映射器和适配器总结

    从上一篇的springmvc入门中已经看到,springmvc.xml中的配置了映射器和适配器,是使用非注解的方式来配置的,这是非注解方式的一种,这里再复习一下: 1. 非注解方式 1.1 处理器适配 ...

  9. Python:Dom生成XML文件(写XML)

    http://www.ourunix.org/post/327.html 在python中解析XML文件也有Dom和Sax两种方式,这里先介绍如何是使用Dom解析XML,这一篇文章是Dom生成XML文 ...

  10. PJSIP dialog inv销毁

    PJSIP的Diaglog(类型为pjsip_dialog) 可以被外部调用,同时PJSIP有自己的机制销毁用户创建的 Dialog,如PJSIP内部销毁了某个Diaglog,用户在不知情的情况下继续 ...