最全Java数据结构————顺序表(增删改查详细实现,java接口开发面试题

读者福利

由于篇幅过长,就不展示所有面试题了,感兴趣的小伙伴

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

更多笔记分享

35K成功入职:蚂蚁金服面试Java后端经历!「含面试题+答案」

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

3.向线性表表添加元素

4.在位置i处插入元素

4.删除指定位置的元素,并返回该元素

5.查找t第一次出现的位置

6.手动扩容方法


1.什么是顺序表

========

在程序中,经常需要将一组(通常是同为某个类型的)数据元素作为整体管理和使用,需要创建这种元素组,用变量记录它们,传进传出函数等。一组数据中包含的元素个数可能发生变化(可以增加或删除元素)。

对于这种需求,最简单的解决方案便是将这样一组元素看成一个序列,用元素在序列里的位置和顺序,表示实际应用中的某种有意义的信息,或者表示数据之间的某种关系。

这样的一组序列元素的组织形式,我们可以将其抽象为线性表。一个线性表是某类元素的一个集合,还记录着元素之间的一种顺序关系。线性表是最基本的数据结构之一,在实际程序中应用非常广泛,它还经常被用作更复杂的数据结构的实现基础。

顺序表是建立在数组的基础上的,我们需要在数组的基础上实现它的特定API功能,具体有什么功能以下

2.顺序表的基本功能和结构

=============

public class SequenceList implements Iterable {

//存储元素的数据

private T[] arr;

//记录当前顺序表中的元素个数

private int N;

//构造方法

public SequenceList(int capacity) {

this.arr= (T[]) new Object[capacity];

this.N=0;

}

解析:首先我们需要一个底层的arr数组来存储元素,这里的T指的是泛型,因为我们还没确定放入的元素类型,有可能放int,String等等,所以先用泛型表示,不明白泛型的可以了解了解。其次用一个N来统计顺序表中的元素个数。在构造方法中,capacity表示我们创建时arr的初始长度,因为泛型是无法直接实例化的,这里我们可以new一个Object数组,因为Object是任何类的父类,所以T为任何类型我们都可以将Object强转为我们需要的数组,N刚开始为0即可。

下面是顺序表需要实现的基本功能

  
public boolean isEmpty()
判断线性表是否为空
public  T get(int i)
获取指定位置的元素
public void add(T t)
向线性表中添加元素t
public void insert(int i,T t)
在i元素处插入元素t
public T remove(int i)
删除指定位置i处的元素,并返回该元素
public int indexOf(T t)
查找t第一次出现的位置
public void reSize(int newLength)
手动实现扩容功能

3.顺序表基本功能的实现和解析

===================

1.判断线性表是否为空


//将一个线性表置为空表

public void clear(){

this.N=0;

}

//判断当前线性表是否为空表

public boolean isEmpty(){

return N==0;

}

解析:判断线性表是否为空,我们只需要返回N是否等于0即可。

2.获取指定位置的元素


//获取指定位置的元素

public T get(int i){

return arr[i];

}

解析:数组可以直接索引对应位置的元素

3.向线性表表添加元素


//向线性表中添加元素t

public void add(T t){

if(N== arr.length){

reSize(2*N);

}

arr[N++]=t;

}

解析:添加时,我们首先判断数组arr是否已经装满,如果满了会先调用我们的扩容方法增加数组长度,在后面会详细解析。然后arr[N]这个位置加入元素即可,然后N会自增1,表示元素个数多了一个。

4.在位置i处插入元素


//在i元素处插入元素t

public void insert(int i,T t){

if(N== arr.length){

reSize(2*N);

}

//把i元素开始后面的元素都向后移一位

for(int j=N-1;j>=i;j–){

arr[j+1]=arr[j];

面试题总结

其它面试题(springboot、mybatis、并发、java中高级面试总结等)

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

X9IAz-1715570132674)]

本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录

需要这份系统化的资料的朋友,可以点击这里获取

  • 26
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值