【数据结构】ArrayList与顺序表

文章目录

一、线性表

线性表(linear list)是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串...

线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。

二、顺序表

顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。

复制代码
public class SeqList {
// 打印顺序表
public void display() { }
// 新增元素,默认在数组最后新增
public void add(int data) { }
// 在 pos 位置新增元素
public void add(int pos, int data) { }
// 判定是否包含某个元素
public boolean contains(int toFind) { return true; }
// 查找某个元素对应的位置
public int indexOf(int toFind) { return -1; }
// 获取 pos 位置的元素
public int get(int pos) { return -1; }
// 给 pos 位置的元素设为 value
public void set(int pos, int value) { }
//删除第一次出现的关键字key
public void remove(int toRemove) { }
// 获取顺序表长度
public int size() { return 0; }
// 清空顺序表
public void clear() { }
}

三、ArrayList简介

在集合框架中,ArrayList是一个普通的类,实现了List接口

【说明】

  1. ArrayList实现了RandomAccess接口,表明ArrayList支持随机访问
  2. ArrayList实现了Cloneable接口,表明ArrayList是可以clone的
  3. ArrayList实现了Serializable接口,表明ArrayList是支持序列化的
  4. 和Vector不同,ArrayList不是线程安全的,在单线程下可以使用,在多线程中可以选择Vector或者
    CopyOnWriteArrayList
  5. ArrayList底层是一段连续的空间,并且可以动态扩容,是一个动态类型的顺序表
相关推荐
霖003 分钟前
C++学习笔记五
开发语言·c++·笔记·学习·青少年编程·个人开发
hello 早上好17 分钟前
MyBatis 核心知识点、插件
java·开发语言·mybatis
飞天荧光棒22 分钟前
Wiz笔记二次开发
开发语言·笔记·python·个人开发
DONG91324 分钟前
Python 函数:从“是什么”到“怎么用”的完整指南
开发语言·windows·python·青少年编程·pycharm
float_六七25 分钟前
MyBatis 在执行 SQL 时找不到名为 name 的参数
java·sql·mybatis
麦兜*29 分钟前
SpringBoot 2.x→3.0升级实战:Jakarta EE兼容性改造清单
java·spring boot·后端·spring·系统架构·maven·springcloud
NE_STOP1 小时前
SpringBoot--学会配置日志
java·spring
悟能不能悟1 小时前
使用 PowerMockito 模拟 new A() 行为
java
天天摸鱼的java工程师1 小时前
蚂蚁金服面试官:你能从JVM源码解释STW吗?
java·后端·面试
BlueBirdssh1 小时前
wpa_supplicant-2.11/src/drivers/driver_nl80211_scan.c
linux·开发语言