ArrayList和顺序表

目录

线性表

顺序表

实现顺序表:

1,添加元素的时候我们要判断是否需要扩容

2,写异常

3,数组清空

ArrayList:

ArrayList的构造方法:

ArrayList的add方法:

ArrayList的subList

知识点补充:数据结构中常见的接口关系图

ArrayList的打印

二维数组:


线性表

就是n个相同类型的数据有序排列;常见的有:顺序表,链表。栈,队列等

顺序表

实现顺序表:

为了更好的掌握ArrayList我们先来定义一个顺序表和接口,用顺序表这个类去实现接口,并重写接口中的所有方法;大家先来自己思考实现。顺序表最基础的两个属性就是数组和有效数组元素的大小

所需要实现的方法:

 // 新增元素,默认在数组最后新增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 位置的元素设为 valuepublic void set(int pos, int value);//删除第一次出现的关键字keypublic void remove(int toRemove);// 获取顺序表长度public int size();// 清空顺序表public void clear() ;// 打印顺序表,注意:该方法并不是顺序表中的方法,为了方便看测试结果给出的public void display() ;

重写方法的代码:(由于代码较长,博主觉得不适合全部放在这里,因为后面学习二叉树等时候代码会更长,但出于详细,才放这里,后面可能不放了(可以看gitee),所以路过的小伙伴可以给博主提建议(放还是不放))

import java.util.Arrays;public class MyArray implements IExcese{public int[] array = {};public int size = 0;public static final int INIT_SIZE = 5;@Override//要判断给出的下标是否合理所以我们要来抛出异常public void add(int data) {array = capitalArray();array[size] = data;size++;}@Override//注意增加的元素不能隔空增加,比如3没有添加元素就直接在4下标添加,add可以理解为插入public void add(int pos, int data) {array = capitalArray();if(pos<size && pos>=0) {int mark = data;for(int i = size - 1;i>pos;i--) {array[i] = array[i - 1];}array[pos] = data;size++;}else {throw new DataOverException("数组下标不符合规范");}}@Overridepublic boolean contains(int toFind) {for(int i = 0; i<size;i++) {if(array[i] == toFind) {System.out.println("下标位置为:" + i);return true;}return false;}return false;}@Overridepublic int indexOf(int toFind) {for (int i = 0; i < size; i++) {if (array[i] == toFind) {return i;}}return -1;}@Overridepublic int get(int pos) {if(pos<0 ||pos>=size) {throw new DataOverException("下表不合理");}else{return array[pos];}}@Overridepublic void set(int pos, int value) {if(pos<0 ||pos>=size) {throw new DataOverException("下表不合理");}else{array[pos]  = value;}}@Overridepublic void remove(int toRemove) {int mark = 0;int i;for(i =0;i<size;i++) {if(array[i] == toRemove) {mark = 1;}}if(mark ==1) {for (int j = i; j < size-1; j++) {array[i] = array[i+1];}size--;}else{System.out.println("没有该元素");}}@Overridepublic int size() {return size;}@Overridepublic void clear() {for (int i =0 ;i<size;i++) {array[i] = null;}size = 0;}@Overridepublic void display() {for(int i = 0;i < size; i++) {System.out.println(array[i]);}}@Overridepublic String toString() {return "MyArray{" +"array=" + Arrays.toString(array) +", size=" + size +'}';}private int[] capitalArray() {if (size == 0 ) {return new int[INIT_SIZE];}else if(size == array.length) {int newSize = size + 5;//扩容数组,返回一个新数组array = Arrays.copyOf(array,newSize);return array;} else {return array;}}
}

大部分代码都比较为简单,我们挑几个来说就行;

1,添加元素的时候我们要判断是否需要扩容

扩容需要的方法Arrays.copyOf(),填两个参数,原数组和需要扩容元素的个数,返回的是原数组类型;

同时在指定位置添加的时候,要将元素后移;还要判断数组下标是否合理,不能小于0也不能大于等于size;

2,写异常

当下标不符合要求的时候我们可以写异常来抛出

3,数组清空

防止资源浪费我们要清空数组,由于数组是引用类型,所以我们清空的时候要将数组赋值为null

ArrayList:

ArrayList就类似数组,但为什么还有创建这个类,是因为当我们需要知道并运用这个数组的有效存储元素时,数组是无法满足的(比如数组整体有五个元素的大小,但实际上只存储了三个元素),而且ArrayList当中有很多方法可以使用;

同时ArrayList是泛型类,意味着你可以定义任意类型的数组

ArrayList的方法:

ArrayList方法的使用就和咱们实现的顺序表差不多,要想更加了解这个类当我们就要看其源码(最开始看源码是一件比较痛苦的事,但是我们必须要学会去了解以及深刨,而且上面顺序表的实现也很重要为了更好理解源码)

ArrayList的构造方法:

ArrayList有三个构造方法

1,带一个参数:

2 不带参数

这些字段均是ArrayList的属性

不带参数的时候创建一个空数组;此时没有给数组分配空间(使用add会分配);

3 参数为数组:

我们来解释一下这个参数是什么意思:
c是变量名,Collection要求传入的参数必须是Collection类型或者其子类,<? extends E>中?是通配符的意思,意思是传入的参数还必须是E或者E的子类,而E又指的是,泛型中传入的类型;

我们通过代码来更好地理解一下:其中<>中传入的类型就代表E,()中传入的数组就代表?;ArrayList是Collection的子类,所以arrayList满足第一个条件,arrayList中的元素均是String类型的,所以当传入参数的元素类型是String或者其子类的时候就可以编译成功;而第三行的E是Integer类型,String不是Integer的子类因此编译失败

ArrayList的add方法:

这是add的源码,其中调用的字段都在上张图有显示所以可以对照来看;

整个代码的思路是:

1 是否初始化,如果没有那么返回一个大小为10的数组;

2 如果初始化那么判断数组是否需要扩容,如果不需要那么返回原数组;如果需要那么进行扩容,在最后一步中判断是否扩容后数组元素是否超过了int的最大值,如果没有,那么扩容成功

3 每次扩容的时候会扩大1,5倍,x>>1,x这个值向右移1相当于除以2;

ArrayList的subList

传入两个参数,第一个是数组的起始下标,第二个是终点下标(左闭右开),相当于字符串的截取。但与字符串不同的是,字符串的改变是产生新的对象,但是subList截取后的数组和原数组指向的是同一个对象,因此改变其中一个数组的值另一个数组也会改变。

subList的返回类型是List,List是ArrayList的实现接口;

知识点补充:数据结构中常见的接口关系图

ArrayList的打印

1 重写toString后可以通过sout传入对象打印

2用for打印;

3用foreach这里包装类类型可以用基础类型接收,因为会自动拆包

4 迭代器,这里有个印象就行

二维数组:

ArrayList<ArrayList<Integer>>or<List<List<Integer>>>是二维数组,ArrayList的每个元素都是ArrayList<Integer>类型;

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

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

相关文章

业务逻辑漏洞

业务逻辑漏洞 扫描器扫不出来 漏洞包括 暴力破解任意用户/密码登陆短信/邮箱轰炸验证码绕过/爆破/重放/回传用户名/手机号枚举(用户名枚举&#xff1a;当用户登录时&#xff0c;显示用户名不存在&#xff0c;或密码不正确&#xff0c;两个其中一个不正确就称为用户名枚举)越…

el-table,列表合并,根据名称列名称相同的品名将其它列值相同的进行合并

el-table,列表合并,根据名称列名称相同的品名讲其它列值相同的进行合并,并且不能垮品名合并 如图 用到el-table合并行的方法合并 tableSpanMethod({ row, column, rowIndex, columnIndex }) {if (column.property "materielName") {//合并商品名const _row this…

一加7Pro为PixelExperience系统编译kernelsu

前言 之前写了一篇文章为一加七Pro(LineageOs17.1 4.14内核版本)编译KernelSu&#xff0c;最近想换个系统玩玩&#xff0c;因为我发现我自己编译的系统总是被某些APP风控了&#xff0c;比如淘宝有些活动就参与不了。 正好可以试试PixelExperience&#xff0c;顺便为PixelExpe…

Django项目部署本地windows IIS(详细版)和static文件设置(页面样式正常显示)

目录 必要条件&#xff1a; 一、下载并启用wfastcgi 二、window安装 IIS功能 三、IIS管理器中添加网站 1、复制项目 2、复制wfastcgi.py文件 3、创建文件web.config 4、添加网站&#xff0c;填写信息 5、启动fastcgi程序 6、修改进程标识 四、static文件设置和正确显…

【2023传智杯】第六届传智杯程序设计挑战赛AB组-DEF题解题分析详解【JavaPythonC++解题笔记】

本文仅为【2023传智杯】第六届传智杯程序设计挑战赛-题目解题分析详解的解题个人笔记,个人解题分析记录。 本文包含:第六届传智杯程序设计挑战赛题目、解题思路分析、解题代码、解题代码详解 文章目录 一.前言更新进度记录二.比赛题目(AB俩组)D题题目-abbE题题目 -kotori和…

Appium 2 和 Appium Inspector 环境部署

前言 自 2022 年 1 月 1 日起&#xff0c;Appium 核心团队不再维护 Appium 1.x。官方支持的平台驱动程序的所有最新版本均不兼容 Appium 1.x&#xff0c;需要 Appium 2 才能运行。 Appium 2是一个自动化移动应用程序的开源工具&#xff0c;它带来了以下重要改进&#xff1a;  …

人工智能原理复习--知识表示(一)

文章目录 上一篇知识概述命题逻辑谓词逻辑谓词逻辑的应用 下一篇 上一篇 人工智能原理复习–绪论 知识概述 知识就是人类认识自然界的精神产物&#xff0c;是人类进行智能活动的基础。 是经过加工的信息&#xff0c;包括事实、信念和启发式规则。 分类&#xff1a; 按作用可…

【数值计算方法(黄明游)】常微分方程初值问题的数值积分法:欧拉方法(向前Euler)【理论到程序】

文章目录 一、数值积分法1. 一般步骤2. 数值方法 二、欧拉方法&#xff08;Euler Method&#xff09;1. 向前欧拉法&#xff08;前向欧拉法&#xff09;a. 基本理论b. 典例解析c. 算法实现 常微分方程初值问题的数值积分法是一种通过数值方法求解给定初始条件下的常微分方程&am…

【C++初阶】五、类和对象(日期类的完善、流运算符重载函数、const成员、“”取地址运算符重载)

相关代码gitee自取&#xff1a; C语言学习日记: 加油努力 (gitee.com) 接上期&#xff1a; 【C初阶】四、类和对象 &#xff08;构造函数、析构函数、拷贝构造函数、赋值运算符重载函数&#xff09;-CSDN博客 一 . 日期类的完善 此次日期类的成员函数&#xff0c;采用声明…

Android中的多进程

在Android中也可以像pc一样开启多进程&#xff0c;这在android的编程中通常是比较少见的&#xff0c;以为在一个app基本上都是单进程工作就已经足够了&#xff0c;有一些特殊的场景&#xff0c;我们需要用多进程来做一些额外的工作&#xff0c;比如下载工作等。 在Android的An…

Elasticsearch底层原理分析——新建、索引文档

es版本 8.1.0 重要概念回顾 Elasticsearch Node的角色 与下文流程相关的角色介绍&#xff1a; Node Roles配置主要功能说明masternode.roles: [ master ]有资格参与选举成为master节点&#xff0c;从而进行集群范围的管理工作&#xff0c;如创建或删除索引、跟踪哪些节点是…

Postman进阶功能实战演练

Postman除了前面介绍的一些功能&#xff0c;还有其他一些小功能在日常接口测试或许用得上。今天&#xff0c;我们就来盘点一下&#xff0c;如下所示&#xff1a; 1.数据驱动 想要批量执行接口用例&#xff0c;我们一般会将对应的接口用例放在同一个Collection中&#xff0c;然…

一种新的基于物理的AlGaN/GaN HFET紧凑模型

标题&#xff1a;A new physics-based compact model for AlGaN/GaN HFETs (IEEE MTT-S International Microwave Symposium) 摘要 摘要 - 针对AlGaN/GaN HFET&#xff0c;提出了一种无拟合参数的物理解析模型。对于非饱和操作&#xff0c;建立了两个接入区和栅极下方I-V特性的…

消息队列进阶-1.消息队列的应用场景与选型

&#x1f44f;作者简介&#xff1a;大家好&#xff0c;我是爱吃芝士的土豆倪&#xff0c;24届校招生Java选手&#xff0c;很高兴认识大家&#x1f4d5;系列专栏&#xff1a;Spring源码、JUC源码、Kafka原理&#x1f525;如果感觉博主的文章还不错的话&#xff0c;请&#x1f44…

函数声明与函数表达式

函数声明 一个标准的函数声明&#xff0c;由关键字function 、函数名、形参和代码块组成。 有名字的函数又叫具名函数。 举个例子&#xff1a; function quack(num) { for (var i 0; i < num; i) {console.log("Quack!")} } quack(3)函数表达式 函数没有名称…

skywalking告警qq邮箱发送

首先开启发送接收qq邮箱的权限 开启之后&#xff0c;会让你发送信息&#xff0c;按着一系列操作&#xff0c;获得password &#xff08;授权码&#xff08;例如&#xff0c;qq开启SMTP授权码&#xff0c;qq授权码16位&#xff09;&#xff09; <!-- mail邮箱-->…

传智杯-题目1

运气 一&#xff1a;对于每一的1到6都进行枚举&#xff0c;进行递归操作 二&#xff1a;如果位数到了指定的n的时候&#xff0c;递归的条件&#xff0c;进行判断是否可以整除操作 #include<iostream> #include<algorithm> using namespace std; long long n, k, an…

Java抽象类:类的幕后黑手,提供继承和扩展的框架。

&#x1f451;专栏内容&#xff1a;Java⛪个人主页&#xff1a;子夜的星的主页&#x1f495;座右铭&#xff1a;前路未远&#xff0c;步履不停 目录 一、抽象类的概念二、注意事项三、抽象类的作用 一、抽象类的概念 在面向对象的概念中&#xff0c;所有的对象都是通过类来描绘…

vue3 element plus 表单验证 数组嵌套对象格式验证 动态验证等

基本结构 model 表单数据对象 rules 验证对象 prop model 的键名 <template><el-form ref"ruleFormRef" :model"ruleForm" :rules"rules"><el-form-item label"手机号" prop"mobile"><el-input v-mod…

鸿蒙原生应用/元服务开发-AGC分发如何生成密钥和和证书请求文件

HarmonyOS通过数字证书&#xff08;.cer文件&#xff09;和Profile文件&#xff08;.p7b文件&#xff09;等签名信息来保证应用的完整性&#xff0c;应用如需上架到华为应用市场必须通过签名校验。因此&#xff0c;开发者需要使用发布证书和Profile文件对应用进行签名后才能发布…