自定义顺序表ArrayList
1.简介
顺序表是在计算机内存中以数组的形式保存的线性表,线性表的顺序存储是指用一组地址连续的存储单元依次存储线性表中的各个元素、使得线性表中在逻辑结构上相邻的数据元素存储在相邻的物理存储单元中,即通过数据元素物理存储的相邻关系来反映数据元素之间逻辑上的相邻关系,采用顺序存储结构的线性表通常称为顺序表。顺序表是将表中的结点依次存放在计算机内存中一组地址连续的存储单元中。
顺序表 ArrayList 是对数组 object[] 的再次封装
相比于数组,顺序表的容量是可变的
2.这里我们尝试自己使用数组封装一个顺序表
using System; namespace DataStructure
{
/// <summary>
/// 自定义顺序表
/// </summary>
public class ArrayListDS
{
private const int _defaulCapacity = 4; //数组的初始容器
private object[] _items; // 存放数据的数组
private int _size = 0; // 元素个数 /// <summary>
/// 无参构造函数,默认容量为0
/// </summary>
public ArrayListDS()
{
this._items = new object[0];
}
/// <summary>
/// 带容量初始化构造函数
/// </summary>
/// <param name="capacity"></param>
public ArrayListDS(int capacity)
{
if (capacity < 0)
throw new ArgumentOutOfRangeException("capacity", "数组长度不能为负数");
this._items = new object[capacity];
}
/// <summary>
/// 元素个数
/// </summary>
public virtual int Count
{
get { return this._size; }
}
/// <summary>
/// 容量
/// </summary>
public virtual int Capacity
{
get { return this._items.Length; }
set
{
if (value != this._items.Length)
{
if (value < this._size)
throw new ArgumentOutOfRangeException("value", "容量太小了");
// 开辟一个新的内存空间存储元素
object[] destinationArray = new object[value];
if (this._size > 0)
Array.Copy(this._items, 0, destinationArray, 0, this._size);
this._items = destinationArray;
}
}
}
/// <summary>
/// 判断扩容
/// </summary>
private void EnsureCapacity()
{
// _items.Length是数组容量,_size是数组个数
if (this._items.Length == this._size)
this.Capacity = this.Capacity + _defaulCapacity;
}
/// <summary>
/// 判断超出索引
/// </summary>
/// <param name="index">索引</param>
private void OutIndex(int index)
{
if (index < 0 || index >= this._size)
throw new ArgumentOutOfRangeException("index", "索引超出范围");
}
/// <summary>
/// 添加元素
/// </summary>
/// <param name="value"></param>
public virtual void Add(object value)
{
EnsureCapacity();
this._items[this._size] = value;
this._size++;
}
/// <summary>
/// 索引器,可获取值、修改值、新增值
/// </summary>
/// <param name="index">索引</param>
/// <returns></returns>
public virtual object this[int index]
{
get
{
OutIndex(index);
return this._items[index];//获取值
}
set
{
if (index < 0 || index > this._size)
throw new ArgumentOutOfRangeException("index", "索引超出范围");
if (index < this._size)//修改值
this._items[index] = value;
if (index == this._size)//新增值
Add(value);
}
}
/// <summary>
/// 裁剪多余容量
/// </summary>
public virtual void TrimToSize()
{
this.Capacity = this._size;
}
/// <summary>
/// 删除指定索引的元素
/// </summary>
/// <param name="index">索引</param>
public virtual void RemoveAt(int index)
{
OutIndex(index);
if (index < this._size - 1)
{
// 使删除元素后的所有元素向前移一位
Array.Copy(this._items, index + 1, this._items, index, this._size - index - 1);
}
// 最后一位置空
this._items[this._size - 1] = null;
this._size--;
}
/// <summary>
/// 插入
/// </summary>
/// <param name="index"></param>
/// <param name="value"></param>
public virtual void Insert(int index, object value)
{
if (index < 0 || index > this._size)
throw new ArgumentOutOfRangeException("index", "索引超出范围");
EnsureCapacity();
if (index < this._size)
{
// 插入点后面的元素后移一位
Array.Copy(this._items, index, this._items, index + 1, this._size - index);
}
this._items[index] = value;
this._size++;
}
}
}
3.ArrayList 和 List<T> 优劣对比
了解了ArrayList 的底层,我们知道它使用的是 object数组,会有装箱和拆箱的消耗
List<T> 使用了泛型,类型安全,比ArrayList 性能更优,不过在使用的过程中 只能指定一种类型。
自定义顺序表ArrayList的更多相关文章
- 数据结构之线性顺序表ArrayList(Java实现)
一.ListMe接口: import java.util.ArrayList; //实现线性表(顺序表和链表)的接口://提供add get isEmpty size 功能public interfa ...
- 三 模拟实现顺序表ArrayList
/** * 顺序表,重点是数组动态扩容,插入 * 底层采用数组,长度可以动态变化,此处采用增长一倍 * java.util.ArrayList每次增长50% * int newCapacity = ...
- Java数据结构-线性表之顺序表ArrayList
线性表的顺序存储结构.也称为顺序表.指用一段连续的存储单元依次存储线性表中的数据元素. 依据顺序表的特性,我们用数组来实现顺序表,以下是我通过数组实现的Java版本号的顺序表. package com ...
- (java实现)顺序表-ArrayList
什么是顺序表 顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构. 在使用顺序表存储数据前,会先申请一段连续的内存空间(即数组),然后把数组依次存入 ...
- C++利用动态数组实现顺序表(不限数据类型)
通过类模板实现顺序表时,若进行比较和遍历操作,模板元素可以通过STL中的equal_to仿函数实现,或者通过回调函数实现.若进行复制操作,可以采用STL的算法函数,也可以通过操作地址实现.关于回调函数 ...
- "《算法导论》之‘线性表’":基于动态分配的数组的顺序表
我们利用静态分配的数组来实现的顺序表的局限还是挺大的,主要在于它的容量是预先定好的,用户不能根据自己的需要来改变.如果为了后续用户能够自己调整顺序表的大小,动态地分配数组空间还是很有必要的.基于动态分 ...
- 数据结构4:顺序表(线性表的顺序存储结构)及C语言实现
逻辑结构上呈线性分布的数据元素在实际的物理存储结构中也同样相互之间紧挨着,这种存储结构称为线性表的顺序存储结构. 也就是说,逻辑上具有线性关系的数据按照前后的次序全部存储在一整块连续的内存空间中,之间 ...
- 【C#】【数据结构】001-线性表:顺序表
C#数据结构:顺序表结构 1.自定义顺序表结构 using System.Collections; using System.Collections.Generic; /// <summary& ...
- C语言实现顺序表(顺序存储结构)
顺序表(顺序存储结构)及初始化过程详解 顺序表,全名顺序存储结构,是线性表的一种.通过<线性表>一节的学习我们知道,线性表用于存储逻辑关系为"一对一"的数据,顺序表自然 ...
- Java数据结构-01顺序表
一.定义 线性表是一种线性结构,它是具有相同类型的n(n≥0)个数据元素组成的有限序列. 二.存储分类 1.顺序存储: ①简述:是指将线性表中的各个元素依次存放在一组地址连续的存储单元中,通常将这种方 ...
随机推荐
- 纷繁复杂见真章,华为云产品需求管理利器CodeArts Req解读
摘要:到底什么是需求?又该如何做好需求管理? 本文分享自华为云社区<纷繁复杂见真章,华为云产品需求管理利器 CodeArts Req 解读>,作者:华为云头条 . 2022 年 8 月,某 ...
- Jenkins服务器上创建项目和配置
大体步骤:General(基础配置)-->源码管理-->构建触发器-->构建环境-->构建-->构建后操作 1.创建一个工程 2.General(基础配置) 仅需填写标准 ...
- Linux 下的输入输出和重定向示例
Linux 下的输入输出和重定向示例 作者:Grey 原文地址: 博客园:Linux 下的输入输出和重定向示例 CSDN:Linux 下的输入输出和重定向示例 说明 Linux 下的输入输出有如下三种 ...
- jQuery基本使用
目录 一:jQuery查找标签 1.基本选择器 二:分组与嵌套 三:组合选择器 四:jQuery基本筛选器 五:属性选择器 1.属性标签 六:JQuery表单筛选器 1.type属性 2.表单对象属性 ...
- 自定义RBAC(5)
您好,我是湘王,这是我的博客园,欢迎您来,欢迎您再来- 把实体类及Service类都准备好了之后,就可以开始继续写业务代码了.Spring Security的强大之一就在于它的拦截器.那么这里也可以参 ...
- 手写promise解决回调地狱问题
在介绍promise之前我们先来看一段代码: 根据案例我们可以看出,这段代码可以无限的嵌套下去,但是每嵌套一层,代码的运行就会降低,而解决回调地狱最好的办法就是new promise 一.什么是 pr ...
- Service层和Dao层的一些自我理解(╥╯^╰╥)(╥╯^╰╥)(学了这么久,这玩意儿似懂非懂的)
学习java已经有很长时间了,但由于是在学校学的,基础不怎么扎实. 这几个月系统的学习,弥补了很多的缺陷,虽然大多数时间都在弄算法(咳咳),我前面的博客有写 如果有认真看过我代码的朋友会发现,我其实英 ...
- Kubernetes的垂直和水平扩缩容的性能评估
Kubernetes的垂直和水平扩缩容的性能评估 译自:Performance evaluation of the autoscaling strategies vertical and horizo ...
- ArcGIS工具 - 按要素裁切数据库
在GIS处理数据中,经常需要分图,将整个任务区划分成若干块,由不同的人协作完成.为了节省分图裁切时间,减少人员操作失误,为源GIS专门制作了按要素裁切数据库工具,以提高数据生产效率. 需求描述 裁切单 ...
- [C#]从两个例子理解async/await
1 例子1 输出的结果为: 可以看出执行的结果为:A--D--B--C--E. 我们再看下一个例子(注意,我们把代码中D和E的位置交换) 2 例子2 结果: 结果为:A--B--C--E--D 3 理 ...