【Java】认识顺序表及常用操作函数(干货满满!!)

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

一、线性表

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

线性表在逻辑上是线性结构,也就说是连续的一条直线。

但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组链式结构的形式存储。


二、什么是顺序表?

首先顺序表的底层是一个数组

为什么不直接使用数组??
在这里插入图片描述

我们来画一个图:(请问这个数组里面有多少有效数据??)

在这里插入图片描述

有人就会说:不是3个吗???
在这里插入图片描述
我说:不要自己数,让程序来知道??

别人说:等于0的时候就跳出来嘛 count计数一下!!!

这样是不可行的:
在这里插入图片描述
我要是0也是数据呢?对吧,这里就有问题。

那么我们可以定义一个变量:这个变量叫做 useSide (代表当前里面有多少有效数据)

这里代表里面有4个数据:
在这里插入图片描述

这里代表里面有4个有效数据:

在这里插入图片描述

所以这就是顺序表的引出:一个顺序表不只一个数组就可以实现,还需要其他的变量(比如(usedSize)


代码实现:
首先我们发现这个对象就是一个 顺序表,里面有数组和 有效数组 变量和一个数组容量:

在这里插入图片描述

看一些main里面实例化对象在内存的一个布局:

在这里插入图片描述
#### 实现顺序表:

基本构成代码:

数组 ,有效数组, 可用容量
public class MyArrayList {
    public int[] elem;  //数组
    public int useSize; //有效数组
    public static int capacity = 10; //可用容量

    public MyArrayList() {   //使用构造方法 初始容量
        this.elem = new int[capacity];
    }
}

三、顺序表的常用操作实现:

要实现的功能:一个个来看

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

(1) 在 pos 位置新增元素

给定指定的位置放入指定的数据:
在这里插入图片描述
先来说一下思路吧:

  1. 判断数组是否满
  2. 判断存放的位置下标是否合法(会不会数组越界)
  3. 如果满了实现扩容
  4. 想存放数据在数组,首先要把后面的数组往后面放一步,这样前面才会有位置放
  5. 存放好数据记住useSize++;(有效数据加1)

我们来看一下图片解析:也是把数组最后的元素往后移动一位
在这里插入图片描述

以上是代码思路,我们来看一下代码是怎么样实现的吧!

 public boolean isFull(){
            //1. 满的情况
            return this.useSize==capacity; //判断useSize和最大容量一样吗 一样就满了
        }

// 在 pos 位置新增元素
        public void add(int pos, int data) {
            if(pos<0 || pos>this.useSize){ //判断下标是否合法
                System.out.println("下标位置不合法");
                return;
            }
            if(isFull()){                //扩容数组大小数组大小
                this.elem = Arrays.copyOf(this.elem,2*capacity); //扩容要新拷贝一份
                capacity *=2;       //容量也要变大
            }

            for (int i = useSize-1; i >=pos ; i--) {
                this.elem[i+1] = this.elem[i];  //当前元素移动到后i+1的位置
            }
            this.elem[pos] = data;
            this.useSize++;
        }

(2) 打印顺序表

思路:遍历数组即可

代码:注意遍历的长度是useSize

// 打印顺序表
        public void display() {

            for (int i = 0; i < this.useSize; i++) {
                System.out.print(elem[i] + " ");
            }
            System.out.println();

        }

(4)判定是否包含某个元素

思路:遍历数组即可

代码:注意遍历的长度是useSize


public boolean isEmpty(){
            return useSize==0;
}

 public boolean contains(int toFind) {
        if (isEmpty()){
            return false;
        }

            for (int i = 0; i < this.useSize; i++) {
                if (elem[i]==toFind){
                    return true;
                }
            }
        return false;
    }

(4)查找某个元素对应的位置

思路:遍历数组即可,找到返回下标

代码:注意遍历的长度是useSize

public int search(int toFind) {
            for (int i = 0; i < elem.length; i++) {
                if (elem[i]==toFind){
                    return i;
                }
            }
        return -1;
    }

(5)获取 pos 位置的元素

思路:直接返回pos下标的数组

代码:

public int getPos(int pos) {
            if (pos<0||pos >=useSize){    
                throw new RuntimeException("当前下标不合法");  //手动抛出异常
            }
            if (isEmpty()){
                throw new RuntimeException("当前顺序表是空的");  //手动抛出异常
            }
            return this.elem[pos];
        }

(5)获取顺序表长度

思路:直接返回useSize 即可

public int size() {
   return this.useSize;
}

(5)给 pos 位置的元素设为 value

思路:直接赋值即可,需要注意下标合法性

public void setPos(int pos, int value) {
                if(pos<0 || pos>= this.useSize){
                    System.out.println("pos不合法");
                }
                if(isEmpty()){
                    System.out.println("顺序表");
                }
                this.elem[pos] =value;
        
        }

(6)删除第一次出现的关键字key

思路:代码和add 有点像,大概原理是找到要删除的元素,然后让下一个元素到当前的元素上面就可以了,最后useSize--;

图片演示:
在这里插入图片描述

代码:

 //删除第一次出现的关键字key
        public void remove(int toRemove) {
        
            if (isEmpty()){  //判断是否为空
                return;
            }
            int index =search(toRemove);  //找到要删除的下标
            if (index==-1){
                return;
            }

            for (int i = index; i <useSize-1; i++) {
                elem[i] = elem[i+1];   //让后面的一个值来前面覆盖
            }
            useSize--;   //有效数 --
        }

思考一个问题为什么要 useSize-1
因为下面的是i+1,如果i走到了 最后一个格子,你在 elem[i] = elem[i+1]; 会 报一个空指针异常:
在这里插入图片描述


(7)清空顺序表

思路:遍历让每一个元素都变成0,最后useSize等于0;
代码:

 public void clear() {
            for (int i = 0; i <useSize; i++) {
                 this.elem[i]=0;
            }
            useSize=0;
        }

相关文章
|
12天前
|
Java 索引
String字符串常用函数以及示例 JAVA基础
String字符串常用函数以及示例 JAVA基础
|
13天前
|
分布式计算 DataWorks Java
DataWorks操作报错合集之在使用MaxCompute的Java SDK创建函数时,出现找不到文件资源的情况,是BUG吗
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
31 0
|
13天前
|
JavaScript 前端开发 Java
Java Script中的函数原型是什么
Java Script中的函数原型是什么
12 0
|
6月前
|
JavaScript 前端开发 Java
javascript实现像java、c#之类的sleep暂停的函数功能
javascript实现像java、c#之类的sleep暂停的函数功能
45 0
|
6月前
|
Java
java实现Beta函数
java实现Beta函数
|
7月前
|
缓存 算法 Java
在阿里云上部署和运行Java函数时
在阿里云上部署和运行Java函数时
103 2
|
13天前
|
Java 计算机视觉 Spring
Java 文件常用操作与流转换
Java 文件常用操作与流转换
|
12天前
|
Java Kotlin
关于Java:public函数公开其public / * package * /’参数类型
关于Java:public函数公开其public / * package * /’参数类型
16 3
|
13天前
|
存储 安全 JavaScript
Java中ArrayList和顺序表
1.线性表2.顺序表3 ArrayList简介4. ArrayList使用4.1 ArrayList的构造4.2 ArrayList常见操作4.3 ArrayList的遍历
|
13天前
|
Java 数据库连接 API
Java 学习路线:基础知识、数据类型、条件语句、函数、循环、异常处理、数据结构、面向对象编程、包、文件和 API
Java 是一种广泛使用的、面向对象的编程语言,始于1995年,以其跨平台性、安全性和可靠性著称,应用于从移动设备到数据中心的各种场景。基础概念包括变量(如局部、实例和静态变量)、数据类型(原始和非原始)、条件语句(if、else、switch等)、函数、循环、异常处理、数据结构(如数组、链表)和面向对象编程(类、接口、继承等)。深入学习还包括包、内存管理、集合框架、序列化、网络套接字、泛型、流、JVM、垃圾回收和线程。构建工具如Gradle、Maven和Ant简化了开发流程,Web框架如Spring和Spring Boot支持Web应用开发。ORM工具如JPA、Hibernate处理对象与数
96 3