自定义实现简易版ArrayList

文章目录

  • 1.了解什么是顺序表
  • 2.实现哪些功能
  • 3.初始化ArrayList
  • 4.实现功能接口
    • 遍历顺序表
    • 判断顺序表是否已满
    • 添加元素
    • 指定下标添加元素
    • 自定义下标不合法异常
    • 判断顺序表是否为空
    • 查找指定元素是否存在
    • 查找指定元素返回下标
    • 获取指定下标的元素
    • 顺序表为空异常
    • 修改指定下标元素的值
    • 删除指定元素
    • 顺序表长度
    • 回收顺序表
  • 完整代码

1.了解什么是顺序表

顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。

2.实现哪些功能

对于一个顺序表来说
我们做的最多的也就是增删查改
则实现以下接口:

public interface IList {//新增元素,默认在数组最后新增public void add(int data);// 在 pos 位置新增元素public void add(int pos, int data);// 判定是否包含某个元素public boolean contains(int toFind) ;// 查找某个元素对应的位置public int indexOf(int toFind);// 获取 pos 位置的元素public int get(int pos);// 给 pos 位置的元素设为 value  更新public void set(int pos, int value);//删除第一次出现的关键字keypublic void remove(int toRemove) ;// 获取顺序表长度public int size();// 清空顺序表public void clear() ;// 打印顺序表,注意:该方法并不是顺序表中的方法,为了方便看测试结果给出的public void display();//判断是否已满boolean isFull();//判断是否为空public boolean isEmpty();
}

3.初始化ArrayList

usedSize为使用的长度
DEFAULT_SIZE = 10为默认顺序表的容量
两个构造方法
无参构造:顺序表默认大小为10;
有参构造:自定义顺序表大小;

public class MyList implements IList{public int[] elem ;public int usedSize;//0//顺序表的 默认大小public static final int DEFAULT_SIZE = 10;public MyList(){this.elem = new int[DEFAULT_SIZE];}public MyList(int capacity){this.elem = new int[capacity];}}

4.实现功能接口

遍历顺序表

public void display(){for (int i = 0; i < usedSize; i++) {System.out.print(elem[i]+" ");}System.out.println();}

判断顺序表是否已满

public boolean isFull(){return usedSize == elem.length;}

添加元素

checkCapacity()判断顺序表是否已满,如果已经满了则进行扩容
扩容为原来顺序表的两倍

 private void checkCapacity(){if(isFull()){elem = Arrays.copyOf(elem,elem.length*2);}}public void add(int data){checkCapacity();elem[this.usedSize] = data;this.usedSize++;}

指定下标添加元素

checkPosOnAdd()判断下标是否合法,如果不合法抛出异常

public void checkPosOnAdd(int pos) throws PosIllegality{if(pos < 0 || pos >usedSize){System.out.println("不合法!");throw new PosIllegality("获取指定下标的元素异常: "+pos);}}public void add(int pos, int data){try{checkPosOnAdd(pos);}catch (PosIllegality e){e.printStackTrace();return;}checkCapacity();for (int i = usedSize-1; i >= pos; i--) {elem[i+1] = elem[i];}elem[pos] = data;usedSize++;}

自定义下标不合法异常

package mylist;public class PosIllegality extends RuntimeException{public PosIllegality(String msg){super(msg);}
}

判断顺序表是否为空

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

查找指定元素是否存在

  public boolean contains(int toFind){if(isEmpty()){return false;}for (int i = 0; i < usedSize; i++) {if(elem[i] == toFind){return true;}}return false;}

查找指定元素返回下标

 public int indexOf(int toFind){if(isEmpty()){return -1;}for (int i = 0; i < usedSize; i++) {if(elem[i] == toFind){return i;}}return -1;}

获取指定下标的元素

public void checkPosOnGetAndSet(int pos) throws PosIllegality {if(pos < 0 || pos >= usedSize){System.out.println("不合法");throw new PosIllegality("获取指定下标的元素异常: "+pos);}}public int get(int pos) throws MyArrayListEmpty{checkPosOnGetAndSet(pos);if(isEmpty()){throw new MyArrayListEmpty("获取指定下标元素时" +"顺序表为空!");}return elem[pos];}

顺序表为空异常

package mylist;public class MyArrayListEmpty extends RuntimeException{public MyArrayListEmpty(String msg){super(msg);}
}

修改指定下标元素的值

public void set(int pos, int value){checkPosOnGetAndSet(pos);elem[pos] = value;}

删除指定元素

  public void remove(int toRemove){int index = indexOf(toRemove);if(index == -1){System.out.println("没有找到");return;}for (int i = index; i < usedSize - 1; i++) {elem[i] =elem[i+1];}usedSize--;}

顺序表长度

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

回收顺序表

 public void clear() {usedSize = 0;}

完整代码

在这里插入图片描述

package mylist;import java.util.Arrays;public class MyList implements IList{public int[] elem ;public int usedSize;//0//顺序表的 默认大小public static final int DEFAULT_SIZE = 10;public MyList(){this.elem = new int[DEFAULT_SIZE];}public MyList(int capacity){this.elem = new int[capacity];}public void display(){for (int i = 0; i < usedSize; i++) {System.out.print(elem[i]+" ");}System.out.println();}public boolean isFull(){return usedSize == elem.length;}private void checkCapacity(){if(isFull()){elem = Arrays.copyOf(elem,elem.length*2);}}public void add(int data){checkCapacity();elem[this.usedSize] = data;this.usedSize++;}public void checkPosOnAdd(int pos) throws PosIllegality{if(pos < 0 || pos >usedSize){System.out.println("不合法!");throw new PosIllegality("获取指定下标的元素异常: "+pos);}}public void add(int pos, int data){try{checkPosOnAdd(pos);}catch (PosIllegality e){e.printStackTrace();return;}checkCapacity();for (int i = usedSize-1; i >= pos; i--) {elem[i+1] = elem[i];}elem[pos] = data;usedSize++;}public boolean isEmpty(){return usedSize == 0;}public boolean contains(int toFind){if(isEmpty()){return false;}for (int i = 0; i < usedSize; i++) {if(elem[i] == toFind){return true;}}return false;}public int indexOf(int toFind){if(isEmpty()){return -1;}for (int i = 0; i < usedSize; i++) {if(elem[i] == toFind){return i;}}return -1;}public void checkPosOnGetAndSet(int pos) throws PosIllegality {if(pos < 0 || pos >= usedSize){System.out.println("不合法");throw new PosIllegality("获取指定下标的元素异常: "+pos);}}public int get(int pos) throws MyArrayListEmpty{checkPosOnGetAndSet(pos);if(isEmpty()){throw new MyArrayListEmpty("获取指定下标元素时" +"顺序表为空!");}return elem[pos];}public void set(int pos, int value){checkPosOnGetAndSet(pos);elem[pos] = value;}public void remove(int toRemove){int index = indexOf(toRemove);if(index == -1){System.out.println("没有找到");return;}for (int i = index; i < usedSize - 1; i++) {elem[i] =elem[i+1];}usedSize--;}public int size(){return this.usedSize;}public void clear() {usedSize = 0;}
}

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Stable DIffusion 炫酷应用 | AI嵌入艺术字+光影光效

目录 1 生成AI艺术字基本流程 1.1 生成黑白图 1.2 启用ControlNet 参数设置 1.3 选择大模型 写提示词 2 不同效果组合 2.1 更改提示词 2.2 更改ControlNet 2.2.1 更改模型或者预处理器 2.2.2 更改参数 3. 其他应用 3.1 AI光影字 本节需要用到ControlNet&#xff0c;可…

手摸手系列之前端Vue实现PDF预览及打印的终极解决方案

前言 近期我正在开发一个前后端分离项目&#xff0c;使用了Spring Boot 和 Vue2&#xff0c;借助了国内优秀的框架 jeecg&#xff0c;前端UI库则选择了 ant-design-vue。在项目中&#xff0c;需要实现文件上传功能&#xff0c;同时还要能够在线预览和下载图片和PDF文件&#x…

[golang 流媒体在线直播系统] 4.真实RTMP推流摄像头把摄像头拍摄的信息发送到腾讯云流媒体服务器实现直播

用RTMP推流摄像头把摄像头拍摄的信息发送到腾讯云流媒体服务器实现直播,该功能适用范围广,比如:幼儿园直播、农场视频直播, 一.准备工作 要实现上面的功能,需要准备如下设备: 推流摄像机&#xff08;监控&#xff09; 流媒体直播服务器(腾讯云流媒体服务器,自己搭建的流媒体服务…

MySQL 面试题——MySQL 基础

目录 1.什么是 MySQL&#xff1f;有什么优点&#xff1f;2.MySQL 中的 DDL 与 DML 是分别指什么&#xff1f;3.✨数据类型 varchar 与 char 有什么区别&#xff1f;4.数据类型 BLOB 与 TEXT 有什么区别&#xff1f;5.DATETIME 和 TIMESTAMP 的异同&#xff1f;6.✨MySQL 中 IN …

Json-Jackson和FastJson

狂神&#xff1a; 测试Jackson 纯Java解决日期格式化 设置ObjectMapper FastJson&#xff1a; 知乎&#xff1a;Jackson使用指南 1、常见配置 方式一&#xff1a;yml配置 spring.jackson.date-format指定日期格式&#xff0c;比如yyyy-MM-dd HH:mm:ss&#xff0c;或者具体的…

线程池(重点)

1.线程池的三大方法 package com.kuang.pool;import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; //Executors工具类 三大方法 //使用线程池&#xff0c;创建线程 public class Demo01 {public static void main(String[] args) { // …

Python + Jmeter 实现自动化性能压测

Step01: Python脚本开发 文件路径&#xff1a;D://wl//testproject//Fone-grpc//project1//test_client.py Python 脚本作用&#xff1a; 通过 grpc 调用底层 c 的接口&#xff0c;做数据库的数据插入与查询操作&#xff0c;然后将返回的结果进行拼接与输出。 2.代码里面将…

LeNet-5

目录 一、知识点 二、代码 三、查看卷积层的feature map 1. 查看每层信息 ​2. show_featureMap.py 背景&#xff1a;LeNet-5是一个经典的CNN&#xff0c;由Yann LeCun在1998年提出&#xff0c;旨在解决手写数字识别问题。 一、知识点 1. iter()next() iter()&#xff1a;…

阿里云无影云电脑介绍_云办公_使用_价格和优势说明

什么是阿里云无影云电脑&#xff1f;无影云电脑&#xff08;原云桌面&#xff09;是一种快速构建、高效管理桌面办公环境&#xff0c;无影云电脑可用于远程办公、多分支机构、安全OA、短期使用、专业制图等使用场景&#xff0c;阿里云百科分享无影云桌面的详细介绍、租用价格、…

【查缺补漏 女娲补天】2023平安

秋招了&#xff0c;只根据自己的情况记录&#xff0c;大概率不会很全。标题是我觉得的重点。既搬砖也搬博客。 Telnet协议 远程登录和管理网路设备的标准协议TCP传输层之上&#xff1a;应用层工作模型&#xff1a;C/S模式&#xff08;client/server&#xff09;服务端端口号默…

Python 数独求解器

文章目录 使用回溯算法在Python中解决数独总结 Sudoku&#xff08;数独&#xff09;是一种基于逻辑的数字填充谜题游戏&#xff0c;最受喜爱的是那些热爱逻辑和推理的人。解决数独谜题有助于提高集中注意力和逻辑思维能力。 本文介绍了如何使用Python解决数独谜题。 使用回溯算…

车联网远程监控管理提升车辆调度效率,实现高效运营

随着智慧城市建设与物联网技术发展&#xff0c;车辆使用4G工业路由器网络实现车联网&#xff0c;并对车上视频监控、GPS定位以及温湿度传感器等信息进行数据采集和实时传输。这些数据的采集和监测将通过4G网络上传到管理平台&#xff0c;为车辆调度和运行效率的优化提供了有力的…

计算机组成原理——基础入门总结(一)

本帖更新一些关于计算机组成原理的重点内容。由于博主考研时并不会考这门课&#xff0c;但是考虑到操作系统中又很多重要晦涩的概念涉及很多诸如内存、存储器、磁盘、cpu乃至各种寄存器的知识&#xff0c;此处挑选一些核心的内容总结复盘一遍——实现声明&#xff1a;本帖的内容…

【微信小程序】外卖点餐效果展示

概述 外卖点餐效果展示&#xff0c;左右布局&#xff0c;快速点餐&#xff0c;商家信息展示等...程序是模仿人家的&#xff0c;所以界面没做什么调整&#xff0c;功能是没啥问题&#xff0c;可以正常使用... 详细 直接看效果图&#xff1a; 可以把这个点餐这个功能分为5部分…

第13篇:ESP32 idf wifi联网使用SNTP同步网络时间LCD ST7920液晶屏显示

第1篇:Arduino与ESP32开发板的安装方法 第2篇:ESP32 helloword第一个程序示范点亮板载LED 第3篇:vscode搭建esp32 arduino开发环境 第4篇:vscodeplatformio搭建esp32 arduino开发环境 ​​​​​​第5篇:doit_esp32_devkit_v1使用pmw呼吸灯实验 第6篇:ESP32连接无源喇叭播…

看完这篇 教你玩转渗透测试靶机Vulnhub——Grotesque:2

Vulnhub靶机Grotesque&#xff1a;1.0.1渗透测试详解 Vulnhub靶机介绍&#xff1a;Vulnhub靶机下载&#xff1a;Vulnhub靶机安装&#xff1a;①&#xff1a;信息收集&#xff1a;②&#xff1a;暴力破解&#xff1a;③&#xff1a;SSH登入&#xff1a;④&#xff1a;提权&#…

day21算法

常见的七种查找算法&#xff1a; ​ 数据结构是数据存储的方式&#xff0c;算法是数据计算的方式。所以在开发中&#xff0c;算法和数据结构息息相关。今天的讲义中会涉及部分数据结构的专业名词&#xff0c;如果各位铁粉有疑惑&#xff0c;可以先看一下哥们后面录制的数据结构…

MapReduce YARN 的部署

1、部署说明 Hadoop HDFS分布式文件系统&#xff0c;我们会启动&#xff1a; NameNode进程作为管理节点DataNode进程作为工作节点SecondaryNamenode作为辅助 同理&#xff0c;Hadoop YARN分布式资源调度&#xff0c;会启动&#xff1a;ResourceManager进程作为管理节点NodeM…

uni-app 实现自定义按 A~Z 排序的通讯录(字母索引导航)

创建 convertPinyin.js 文件 convertPinyin.js 将下面的内容复制粘贴到其中 const pinyin (function() {let Pinyin function(ops) {this.initialize(ops);},options {checkPolyphone: false,charcase: "default"};Pinyin.fn Pinyin.prototype {init: functi…

JavaScript:二进制数组【笔记】

二进制数组【ArrayBuffer对象、Type的Array视图和DataView视图】JavaScript操作二进制数据的一个接口。 这些接口原本是和WebGL有关【WebGL是浏览器与显卡之间的通信接口】&#xff0c;为了满足JavaScript与显卡之间大量、实时数据交换&#xff0c;那么JavaScript和显卡之间的…