首页 技术 正文
技术 2022年11月7日
0 收藏 714 点赞 499 浏览 3136 个字

一、定义

  线性表是一种线性结构,它是具有相同类型的n(n≥0)个数据元素组成的有限序列。

二、存储分类

  1.顺序存储:

    ①简述:是指将线性表中的各个元素依次存放在一组地址连续的存储单元中,通常将这种方法存储的线性表称为顺序表;数组中稍微复杂一点的是多维数组和动态数组。对于Java而言,Collection集合中提供了ArrayList和Vector。

    ②特点:数据是连续的;随机访问速度快;

     ③实现方式:一维数组

     

    ④顺序表相关操作:

      A.顺序表的插入

        

      B.顺序表的删除

        

    ⑤代码实现(动态数组案例): 

@SuppressWarnings("unchecked")
public class ArrayList<E> { //数组中存在的元素数量(与容器大小不同,size<=DEFAULT_CAPACITY)
private int size; //所有元素
private E[] elements; //默认的容器大小
private static final int DEFAULT_CAPACITY = 10;
//不存在默认返回的值
private static final int ELEMENT_NOT_FOUND = -1; /**
* 创建一个自定义容量大小的动态数组,自定义大小不能小于DEFAULT_CAPACITY
*
* @param capaticy 容量大小
*/
public ArrayList(int capaticy) {
capaticy = (capaticy < DEFAULT_CAPACITY) ? DEFAULT_CAPACITY : capaticy;
elements = (E[]) new Object[capaticy];
} public ArrayList() {
this(DEFAULT_CAPACITY);
} /**
* 清除所有元素
*/
public void clear() {
for (int i = 0; i < size; i++) {
elements[i] = null;
}
size = 0;
} /**
* @return 元素的数量
*/
public int size() {
return size;
} /**
* @return 是否为空(true空 false不为空)
*/
public boolean isEmpty() {
return size == 0;
} /**
* @param element 所判断的元素
* @return 是否包含某个元素(true包含 false不包含 )
*/
public boolean contains(E element) {
return indexOf(element) != ELEMENT_NOT_FOUND;
} /**
* 添加元素到尾部
*
* @param element 添加的元素
*/
public void add(E element) {
add(size, element);
} /**
* 在index位置插入一个元素
*
* @param index
* @param element
*/
public void add(int index, E element) {
//检查添加的位置对不对
rangeCheckForAdd(index);
//检测 size+1<=容器容量 (true不扩容 false扩容)
ensureCapacity(size + 1); for (int i = size; i > index; i--) {
elements[i] = elements[i - 1];
}
elements[index] = element;
size++;
} /**
* 获取index位置的元素
*
* @param index
* @return
*/
public E get(int index) {
rangeCheck(index);
return elements[index];
} /**
* 修改在index位置的元素
*
* @param index
* @param element
* @return 原来的元素ֵ
*/
public E set(int index, E element) {
rangeCheck(index); E old = elements[index];
elements[index] = element;
return old;
} /**
* 删除index位置的元素
*
* @param index
* @return
*/
public E remove(int index) {
rangeCheck(index); E old = elements[index];
for (int i = index + 1; i < size; i++) {
elements[i - 1] = elements[i];
}
elements[--size] = null;
return old;
} /**
* 查看元素的索引
*
* @param element
* @return
*/
public int indexOf(E element) {
if (element == null) { // 1
for (int i = 0; i < size; i++) {
if (elements[i] == null) return i;
}
} else {
for (int i = 0; i < size; i++) {
if (element.equals(elements[i])) return i; // n
}
}
return ELEMENT_NOT_FOUND;
} /**
* 保证要有capacity的容量
*
* @param capacity
*/
private void ensureCapacity(int capacity) {
//数组的容量,用length是为了获取自定义的容量
int oldCapacity = elements.length;
if (oldCapacity >= capacity) return; // 新容量为旧容量的1.5倍
int newCapacity = oldCapacity + (oldCapacity >> 1);
E[] newElements = (E[]) new Object[newCapacity];
for (int i = 0; i < size; i++) {
newElements[i] = elements[i];
}
elements = newElements; System.out.println(oldCapacity + "扩容为" + newCapacity);
} /**
* 抛出越界异常
* @param index
*/
private void outOfBounds(int index) {
throw new IndexOutOfBoundsException("Index:" + index + ", Size:" + size);
} /**
* 检查index是不是在[0,size]的范围
* @param index
*/
private void rangeCheck(int index) {
if (index < 0 || index >= size) {
outOfBounds(index);
}
} /**
* 添加元素在index上时,判断index是否在[0,size)的范围
* @param index
*/
private void rangeCheckForAdd(int index) {
if (index < 0 || index > size) {
outOfBounds(index);
}
} @Override
public String toString() {
StringBuilder string = new StringBuilder();
string.append("size=").append(size).append(", [");
for (int i = 0; i < size; i++) {
if (i != 0) {
string.append(", ");
}
string.append(elements[i]);
}
string.append("]");
return string.toString();
}
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,000
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,512
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,358
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,141
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,771
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,849