【线性表】:顺序表里一些主要功能的实现

news2024/9/21 23:28:48

框架

image.png


线性表


  • n 个具有相同特征的数据元素的有限序列
    常见的线性表:顺序表、链表、栈、队列…

  • 线性表在逻辑上是线性结构,也就是连续的一条直线
    但在物理结构上不一定是连续的,线性表在物理上存储时,通常以数组链式结构的形式进行存储
    image.png|581

顺序表

  • 顺序表其实就是一个数组,是用一段物理地址连续的存储单元依次存储数据元素的线性结构
  • 其访问速度比较快,给定下标情况下,速度为O(1)
  • 适用于经常进行下标查找或者更新的操作

顺序表实现逻辑

  1. 创建一个 IList 接口,用来放所有相关的方法
  2. 创建一个 MyArrayList 类,数组成员变量 int[ ] elem 用来放数据,整形成员变量 usedSize 用来记录数组里面的数据个数
  3. MyArrayList 类里面实现 IList 接口,并重写里面的方法

各种方法的实现

boolean isFull()——判断数组是否放满

  • 直接返回 usedSize == elem.length 即可,相等为 true,不相等为 false
    @Override
    public boolean isFull() {
        return usedSize == elem.length;
    }

void add(int data)——在数组末尾插入新元素

  1. 首先用 isFUll() 方法判断数组是否装满,若装满,就调用 ArrayscopyOf(elem, 2*elem.length) 方法对数组进行扩容
  2. 将第 usedSize 位的数组元素赋值为 data
  3. usedSize++;
    @Override
    public void add(int data) {
        if(isFull()){
            //如果满了,就扩容为原来的两倍
            elem = Arrays.copyOf(elem,elem.length*2);
        }
        elem[usedSize] = data;
        usedSize++;
    }

void add(int pos, int data)——在指定位置插入元素

  1. 首先判断传入的参数 pos 是否合法
    • 我们创建一个 checkPosOfAdd(int pos) 方法来进行判断,
    • (pos < 0 || pos >= usedSize) ,则抛出一个自定义异常 PosNotLegalException
  2. 再用 isFull() 方法判断数组是否装满,若装满,就调用 ArrayscopyOf(elem, 2*elem.length) 方法对数组进行扩容
  3. 移动元素,将后面的元素从后往前依次向后移一位 elem[usedSize] = elem[usedSize - 1];
  4. 插入元素,elem[pos] = data;
  5. usedSize++;
    @Override
    public void add(int pos, int data) {
        //判断输入的 pos 是否合法
        try{
            checkAddPos(pos);
        }catch (PosNotLegalException e){
            e.printStackTrace();
        }
        //判断数组是否装满
        if(isFull()){
            elem = Arrays.copyOf(elem,elem.length*2);
        }
        //移动元素
        for (int i = usedSize - 1; i >= pos; i--) {
            elem[i + 1] = elem[i];
        }
        //插入元素
        elem[pos] = data;
        usedSize++;
    }
void checkPosOfAdd(int pos)——检查传入add方法中的pos是否合法
  • 若不合法则抛出一个自定义异常 PosNotLegalException
private void checkPosOfAdd(int pos) throws PosNotLegalException{  
    if(pos < 0 || pos > usedSize){  
        //自定义一个异常类:PosNotLegalException  
        throw new PosNotLegalException("pos位置不合法");    
    }
}

PosNotLegalException——传入参数不合法的自定义异常
  • 继承自运行时异常 RuntimeException
public class PosNotLegalException extends RuntimeException{  
    public PosNotLegalException(String msg) {  
        super(msg);  
    }
}

boolean contain(int toFind)——判断是否包含某个元素

  1. 遍历数组 usedSize 次
  2. elem[i] == toFind 时,return true;
  3. 找不到,return false;
public boolean contains(int toFind) {  
    //只需要寻找useSize次  
    for (int i = 0; i < usedSize; i++) {  
        if(elem[i]==toFind){  
            return true;  
        }    
    }   
    return false;  
}

int indexOf(int toFind)——查找某个对应元素的位置

  1. 遍历数组 usedSize
  2. elem[i] == toFind 时,return i;
  3. 找不到,return 0;
public int indexOf(int toFind) {  
    for (int i = 0; i < usedSize; i++) {  
        if(elem[i] == toFind)  
            return i;  
    }    return -1;  
}

int get(int pos)——获取pos位置的元素

  1. 判断传入的参数 pos 是否合法
    • 创建 checkPosOfGetAndSet(int pos) 方法来进行判断
    • (pos < 0 || pos > usedSize),则抛出自定义异常 PosNotLegalException
  2. 合法,return elem[pos];
public int get(int pos) {  
    try{  
        checkPosOfGet(pos);  
    }catch (PosNotLegalException e){  
        e.printStackTrace();  
    }    return elem[pos];  
}  

void checkPosOfGetAndSet(int pos)——判断输入get和set方法的值是否合法
  • 若不合法则抛出一个自定义异常 PosNotLegalException
private void checkPosOfGet (int pos) throws PosNotLegalException{  
    if(pos < 0 || pos > usedSize){  
        throw new PosNotLegalException("pos位置不合法");  
    }
}

void set(int pos, int value)——将pos位置的元素设为value

  1. 判断传入的参数 pos 是否合法
    • 调用 checkPosOfGetAndSet(int pos) 方法来进行判断
    • (pos < 0 || pos > usedSize),则抛出自定义异常 PosNotLegalException
  2. 赋值:elem[pos] == value;
public void set(int pos, int value) {  
    try {  
        checkPosOfGetAndSet(pos);  
    } catch (PosNotLegalException e) {  
        e.printStackTrace();  
    }    
    elem[pos] = value;  
}

void remove(int toRemove)——删除第一次出现的关键字

  1. 调用 indexOf() 方法,获取关键字的下标,并对下标进行判断,若 pos == -1,则输出“未找到
  2. 移动元素,将后面的元素从后往前依次向后移一位 elem[pos] = elem[pos + 1];
  3. usedSize--;
public void remove(int toRemove) {  
    int pos = indexOf(toRemove);  
  
    if (pos == -1) {  
        System.out.println("没有要找的关键字");  
    }    for (int i = pos; i < usedSize - 1; i++) {  
        elem[i] = elem[ i + 1];  
    }    this.usedSize--;  
}

void removeAll(toRemove)——删除所有出现的关键字

  1. 使用 for 循环多次调用 indexOf() 方法,若 pos != -1,则继续操作
  2. 移动元素,将后面的元素从后往前依次向后移一位 `elem[pos] = elem[pos + 1];
  3. usedSize--;
public void removeAll(int toRemove) {  
    for (int i = 0; i < usedSize; i++) {  
        int pos = indexOf(toRemove);  
        if (pos != -1) {  
            for (int j = pos; j < usedSize - 1; j++) {  
                elem[j] = elem[j + 1];  
            }            
            usedSize--;  
        }    
    }
}

void clear()——清空顺序表

  • 因为是基本类型,直接 usedSize = 0 即可
  • 若是引用类型,则需将每一个位置的数据都置为 null (防止内存泄露)
public void clear() {  
    usedSize = 0;  
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1940163.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据结构(栈及其实现)

栈 概念与结构 栈&#xff1a;⼀种特殊的线性表&#xff0c;其只允许在固定的⼀端进⾏插⼊和删除元素操作。 进⾏数据插⼊和删除操作的⼀端称为栈顶&#xff0c;另⼀端称为栈底。栈中的数据元素遵守后进先出 LIFO&#xff08;Last In First Out&#xff09;的原则。 压栈&…

Windows版MySQL5.7解压直用(如何卸载更换位置重新安装)

文章目录 停止mysql进程及服务迁移整个mysql文件夹删除data重启计算机重新安装 停止mysql进程及服务 net stop mysql mysqld -remove mysql迁移整个mysql文件夹 删除data 重启计算机 shutdown -r -t 0重新安装 https://blog.csdn.net/xzzteach/article/details/137723185

【Socket 编程 】基于UDP协议实现通信并添加简单业务

文章目录 前言实现echo server对于服务器端对于客户端UdpServer.hpp文件nococpy.hpp文件InetAddr.hpp头文件Log.hpp头文件UdpServerMain.cpp源文件UdpClientMain.cpp源文件运行结果 实现翻译业务Dict.hpp头文件UdpServerMain.cppUdpserver.hpp运行结果 前言 在了解了Socket编程…

最优化理论与方法-第十一讲-线性规划-极点的刻画

文章目录 1. 概述2. 线性规划定义3. 多面体的基本性质3.1 定义3.2 证明13.3 证明2 B站老师学习视频 1. 概述 线性规划的标准形式&#xff1b;多面体的几何分解&#xff1b;单纯形法&#xff1b;对偶单纯形法 2. 线性规划定义 线性规划Linear Programming&#xff1a;目标函数…

Ubuntu16.04环境下Baxter机器人开发环境搭建要点说明

Ubuntu16.04环境下Baxter机器人开发环境搭建要点说明 前面写过一篇文章&#xff0c;描述了在ubuntu20.04环境下baxter机器人开发环境的搭建&#xff0c;本人在后来的使用中&#xff0c;出于一些原因又在ubuntu16环境下搭建了开发环境&#xff0c;二者总体流程基本类似&#xf…

【数据分享】2013-2022年我国省市县三级的逐年SO2数据(excel\shp格式\免费获取)

空气质量数据是在我们日常研究中经常使用的数据&#xff01;之前我们给大家分享了2000——2022年的省市县三级的逐年PM2.5数据和2013-2022年的省市县三级的逐年CO数据&#xff08;均可查看之前的文章获悉详情&#xff09;&#xff01; 本次我们分享的是我国2013——2022年的省…

【Spark官方文档部分翻译】RDD编程指南(RDD Programming Guide)

写在前面 内容如何选择 本翻译只翻译本人认为精华的部分&#xff0c;本人认为的Spark的一些核心理念&#xff0c;编程思想。一些特别基础的操作包括但不限于搭建环境就不在此赘述了。 配套版本 本系列基于Spark 3.3.1&#xff0c;Scala 2.12.10&#xff0c;进行翻译总结 原…

pycharm报错:No module named pip/No module named pytest

1、问题概述? 今天在执行一个python脚本的时候,控制台提示:No module named pytest,就是没有pytest模块,于是我使用pip命令进行安装,命令如下; pip install pytest 结果又提示No module named pip,说我没有pip模块,没办法,再安装pip 2、安装pip-方式1 在pycharm的T…

路由表与IP数据报转发:基础小白指南

目录 1. 路由表的基本概念 2. 路由表中的默认路由 3. IP数据报的转发流程 4. 路由聚合 5. 最长前缀匹配 总结 在网络世界中&#xff0c;IP数据报的转发是如何进行的&#xff1f; 这篇文章将带你深入了解路由表的基本概念和IP数据报的转发流程。我们会用简洁明了的语言和实…

华为mate20 激活设备

升级失败 需要 准备2个usb线 一根usb1.0工程线 一根正常线 。工程线怎么做&#xff0c;找一个10k电阻 把红线和绿线连起来。我用的是贴片电阻103 大概是2512 1W&#xff0c;也可以用金属膜电阻 步骤① 热风枪吹开后盖

vscode下运行django项目(命令与可视化操作两种方式python .\demo\manage.py runserver)

文章目录 实验前提1. 命令方式操作2. code图形方式操作 实验前提 vscode配置django环境并创建django项目&#xff08;全图文操作&#xff09; https://blog.csdn.net/xzzteach/article/details/140591167 1. 命令方式操作 python .\demo\manage.py runserver关闭运行 2. c…

App Instance 架构示例

前言 在Unity程序设计过程中&#xff0c;我们处理的第一个对象是Application Instance。 它的主要职责是启动流程管理、卸载流程管理&#xff0c;次要职责是管理在内部的子系统生命周期。其他职责&#xff0c;提供或桥接应用程序的配置信息、及其他第三方接口。 它通常以单例的…

buu做题(7)

[BJDCTF2020]Mark loves cat 开始的界面没啥东西, 看了下源码好像也没啥东西 用dirsearch扫描一下 有git 泄露 用工具githack下载源码 <?phpinclude flag.php;$yds "dog"; $is "cat"; $handsome yds;foreach($_POST as $x > $y){$$x $y; }f…

【过题记录】 7.21

Mad MAD Sum 算法&#xff1a;思维&#xff0c;前缀最大值 模拟一下他的运行过程就会发现&#xff0c;两次之后整个数组就固定了&#xff0c;之后每次都是每个数往后移动一位&#xff0c;可以模拟两次之后计算每个数的存活轮数&#xff0c;计算贡献。 #include<bits/stdc.h…

FreeRTOS 任务的挂起与恢复

任务的挂起与恢复的API函数 挂起 - vTaskSuspend 挂起任务类似暂停&#xff0c;可恢复&#xff1b; 删除任务&#xff0c;无法恢复&#xff0c;类似“人死两清” 使用 必须将 INCLUDE_vTaskSuspend 定义为 1 才能使用此函数 void vTaskSuspend( TaskHandle_t xTaskToSuspen…

GIT命令学习 二

&#x1f4d1;打牌 &#xff1a; da pai ge的个人主页 &#x1f324;️个人专栏 &#xff1a; da pai ge的博客专栏 ☁️宝剑锋从磨砺出&#xff0c;梅花香自苦寒来 ☁️运维工程师的职责&#xff1a;监…

PostgreSQL简介和安装

一、Postgresql简介&#xff1a; 1、PostgreSql是功能强大的&#xff0c;开源的关系型数据库&#xff0c;底层基于C语言实现&#xff1b; 2、开源&#xff1a;允许对PostgreSql进行封装&#xff0c;用于商业收费&#xff1b; 3、版本迭代速度快&#xff0c;正式版本已经到15.R…

《昇思25天学习打卡营第24天|基于 MindSpore 实现 BERT 对话情绪识别》

1. BERT 模型概述 BERT&#xff08;Bidirectional Encoder Representations from Transformers&#xff09;是一个预训练的语言表示模型&#xff0c;可以应用于多种自然语言处理任务&#xff0c;包括对话情绪识别。BERT 通过双向 Transformer 编码器&#xff0c;能同时考虑句子…

【Langchain大语言模型开发教程】基于文档问答

&#x1f517; LangChain for LLM Application Development - DeepLearning.AI Embedding&#xff1a; https://huggingface.co/BAAI/bge-large-en-v1.5/tree/main 学习目标 1、Embedding and Vector Store 2、RetrievalQA 引包、加载环境变量 import osfrom dotenv import…

单例模式_Golang

目录 一、单例模式 1.1 基本概念 1.2 使用场景 二、Golang实现 2.1 懒汉模式&#xff08;Lazy Loading&#xff09; 一、单例模式 1.1 基本概念 一个类只能生成一个实例&#xff0c;且该类能自行创建这个实例的一种模式,这个定义个人感觉可以拆的通俗一些,在项目的生命周…