Java顺序表(1)

🐵本篇文章将对顺序表中的方法进行模拟实现


一、线性表

线性表是指在逻辑结构上呈连续的线性结构,而在物理结构上不一定是连续的结构,常见的线性表有:顺序表、链表、栈、队列等

二、顺序表

顺序表一般采用数组来存储数据,因此它是一种逻辑结构上连续,在物理结构上也连续的数据结构,下面对顺序表的增删查改等操作用Java进行具体实现

先实现一个接口,在这个接口写上要实现的方法:

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

之后再创建一个MyArrayList类实现上述接口并重写接口中所有的方法

public class MyArrayList implements IList{public int[] elem; //存储数据public int usedSize; //已经放入顺序表中数据的个数public static final int DEFAULT_CAPACITY = 5; //顺序表中默认容量的大小为5public MyArrayList() {elem = new int[DEFAULT_CAPACITY];}/*以下是要重写IList接口中的方法*/...}

2.1 方法的实现

void add(int data); // 新增元素,默认在数组尾部新增

在数组的尾部新增一个元素,之前的ArrayList类中有一个变量为usedSize,用于记录顺序表中已存数据的个数,刚开始存入数据的时候usedSize为0,那么每次向数组中存入一个数据,usedSize就加1

public void add(int data) {elem[usedSize] = data;usedSize++;
}

写到这里还要考虑一个问题:如果数组满了怎么办,我们前面定义了数组的默认大小为5,如果已经向数组中存入了5个数据在存数据的话,就会抛出数组越界异常,所以在向数组中新增元素时要先判断一下数组满没满,如果满了则要扩容,然后再新增元素

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

Arrays.copyOf的方法定义如下:

public static int[] copyOf(int[] original, int newLength)

int[] original为源数组,newLength为该数组的新长度


void add(int pos, int data); // 在 pos 位置插入元素

那么接下来有一个问题,这些元素怎么移动?是从后往前移动还是从前往后移动,答案是从后往前移动,因为如果从前往后移动的话,先将2放在了3的位置处,如果再要将3移动到4位置时发现3已经被2覆盖了,所以要从5开始倒着依次向后移动

public void add(int pos, int data) {for (int i = usedSize; i >= pos; i--) {//循环条件为i >= pos,因为pos位置处的元素也要往后移动elem[i] = elem[i - 1];}elem[pos] = data; //移动完后,直接再pos位置处插入新增元素
}

写到这里后还要考虑两点:1.pos位置是否合法;2. 此时数组有没有满

先来看第一个:pos位置是否合法,这个很简单,我们可以在第一句加上一个判断pos的方法,如果pos不合法则抛出一个异常使程序终止

public class EmptyException extends RuntimeException{public EmptyException(String message) {super(message);}
}========================================================private void checkPosAdd(int pos) {if (pos < 0 || pos >= usedSize + 1) {//数组的下标不能为0;在一个位置插入后,必须是连续的因为前面说过顺序表在物理结构上也是连续的throw new PosException("下标错误");}
}

判断数组满没满跟之前一样,以下是该方法的最终实现:

public void add(int pos, int data) {checkPosAdd(pos);if (usedSize == elem.length) {elem = Arrays.copyOf(elem, 2 * elem.length);}for (int i = usedSize; i >= pos; i--) {elem[i] = elem[i - 1];}elem[pos] = data;usedSize++;
}

boolean contains(int toFind); // 判定数组中是否包含某个元素

实现这个方法很简单,只需要遍历一遍数组即可

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

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

同样,这个方法也遍历一遍数组即可

public int indexOf(int toFind) {for (int i = 0; i < usedSize; i++) {if (elem[i] == toFind) {return i;}}return -1; //如果没有这个元素,返回-1
}

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

要先判断一下pos位置是否合法

private void checkPosGet(int pos) {if (pos < 0 || pos >= usedSize) {//这里pos >= usedSize 的原因是usedSize代表当前已存数据的个数,该位置还没有放元素throw new PosException("下标错误");}
}

get方法的最终实现:

public int get(int pos) {checkPosGet(pos);return elem[pos];
}

void set(int pos, int value); // 给 pos 位置的元素设为 value

该方法的实现和get方法几乎一致

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

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

在移动元素之前,要先得到toRemove的下标,可以直接利用刚刚实现的indexOf方法,得到下标后开始移动元素,移动完元素就相当于已经将toRemove删除了,那么让usedSize减1

public void remove(int toRemove) {int pos = indexOf(toRemove);for (int i = pos; i < usedSize - 1; i++) {elem[i] = elem[i + 1];}usedSize--;
}

在方法的开始还要判断一下数组是否为空,如果为空则不能删除,可以抛出一个异常

public class EmptyException extends RuntimeException{public EmptyException(String message) {super(message);}
}=======================================================public void remove(int toRemove) {if (usedSize == elem.length) {throw new EmptyException("顺序表为空");}int pos = indexOf(toRemove);for (int i = pos; i < usedSize - 1; i++) {elem[i] = elem[i + 1];}usedSize--;
}

int size(); // 获取顺序表长度

直接返回usedSize即可

int size() {return usedSize;
}

void clear(); // 清空顺序表

具体实现:

    public void clear() {usedSize = 0; //这里的顺序表中放的都是int类型而非引用类型,所以,不用将每个元素置空//如果顺序表中的元素都是引用类型则应遍历数组,将每个元素置空,再将usedSize置为0                                                         }


void display(); // 打印顺序表,注意:该方法并不是顺序表中的方法,为了方便看测试结果给出的

遍历数组并打印即可:

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

🙉本篇文章到此结束,下一篇文章将对ArrayList进行讲解

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

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

相关文章

【STM32】| 01——常用外设 | USART

系列文章目录 【STM32】| 01——常用外设 | USART 失败了也挺可爱&#xff0c;成功了就超帅。 文章目录 前言1. 基础理论1.1 并行通信和串行通信1.2 同步通信和异步通信1.3 单工/半双工/全双工1.4 电平信号(RS232/TTL)和差分信号(RS485)1.5 端口(COM) 2. 串口理论2.1 串口物理…

Springboot+RocketMQ通过事务消息优雅的实现订单支付功能

目录 1. 事务消息 1.1 RocketMQ事务消息的原理 1.2 RocketMQ订单支付功能设计 1. 事务消息 RocketMQ的事务消息&#xff0c;是指发送消息事件和其他事件需要同时成功或同时失败。比如银行转账&#xff0c; A银行的某账户要转一万元到B银行的某账户。A银行发送“B银行账户增加…

高级分布式系统-第3讲 网络与网络互联

万维网的诞生 1957年10月4日&#xff0c; 苏联发射了人类第一颗人造卫星—斯普特尼克一号 美国政府震惊不已。 他们认为&#xff0c; 在日趋激烈的冷战对抗中&#xff0c; 自己已经全面落后于苏联。 为了扭转这一局面&#xff0c; 美国国防部很快于1958 年 2 月组建了一个神秘…

Fastdata极数公司介绍

【写在开头】 前不久看到一句话和一个新闻&#xff0c;“数据作为主要生产要素&#xff0c;以资源化为起点&#xff0c;经历资产化、资本化阶段&#xff0c;逐步实现数据价值。” 2023年10月25日&#xff0c;国家数据局正式揭牌&#xff0c;由国家发展和改革委员会管理。 初看…

linux安装node.js

先去官网下载对应的版本 官网&#xff1a;https://nodejs.org/en/download 选择对应的版本&#xff0c;点这个&#xff0c;直接去虚拟机上面安装 # apt的系统 apt install -y wget # yum的系统 yum install -y wget下载包 wget https://nodejs.org/dist/v20.10.0/node-v20.…

【小白专用】(C#)用户、角色、权限控制体系

我们在开发很多项目的时候,都会用到用户权限管理,我也在很多项目里做过权限控制,所以,我也总结出一套条理清晰的角色权限控制体系。本文采用RBAC&#xff08;Role Based Access Control&#xff09;的基本思想&#xff0c;RBAC&#xff08;角色访问控制&#xff09;的基本思想可…

Java可视化大屏智慧工地云平台源码(SaaS模式)

智慧工地是一种崭新的工程现场一体化管理模式&#xff0c;是互联网与传统建筑行业的深度融合。它充分利用移动互联、物联网、云计算、大数据等新一代信息技术&#xff0c;围绕人、机、料、法、环等各方面关键因素&#xff0c;彻底改变传统建筑施工现场参建各方现场管理的交互方…

5G前装搭载率即将迈过10%大关,车载通讯进入多层次增长通道

对于智能化来说&#xff0c;车载通讯性能的提升&#xff0c;对于相关功能的用户体验优化、进一步减少通讯时延以及打开应用新空间&#xff0c;至关重要。 目前&#xff0c;2G/3G正在进入运营商逐步关闭运营的阶段&#xff0c;4G依然是主力&#xff0c;但5G也在迎来新的增长机会…

imazing破解版百度云2.17.3(附激活许可证下载)

iMazing是一款强大的 iOS 设备管理软件&#xff0c;不管是 iPhone、iPad 或 iPod Touch 设备&#xff0c;只要将 iOS 设备连接到计算机&#xff0c;就可以处理不同类型的数据。 iPhone 和 iPad 备份 借助 iMazing 的独有 iOS 备份技术&#xff08;无线、隐私和自动&#xff09…

强化学习的数学原理学习笔记 - 策略梯度(Policy Gradient)

文章目录 概览&#xff1a;RL方法分类策略梯度&#xff08;Policy Gradient&#xff09;Basic Policy Gradient目标函数1&#xff1a;平均状态值目标函数2&#xff1a;平均单步奖励&#x1f7e1;PG梯度计算 &#x1f7e6;REINFORCE 本系列文章介绍强化学习基础知识与经典算法原…

速卖通跨境智星:解决IP及环境问题,实现批量注册轻松搞定

如果想要注册大批量的速卖通买家号&#xff0c;关键问题之一就是IP及浏览环境的管理。为了确保每个账号都能独立运行&#xff0c;使用独立的IP是必不可少的。近期&#xff0c;速卖通跨境智星备受关注&#xff0c;支持绑定代理IP&#xff0c;并内置反指纹技术&#xff0c;为用户…

WinForms中的UI卡死

WinForms中的UI卡死 WinForms中的UI卡死通常是由于长时间运行的操作阻塞了UI线程所导致的。在UI线程上执行的操作&#xff0c;例如数据访问、计算、文件读写等&#xff0c;如果耗时较长&#xff0c;会使得UI界面失去响应&#xff0c;甚至出现卡死的情况。 解决方法 为了避免…

USACO(美国计算机竞赛)详细介绍 如何备赛 训练资料整理

竞赛简介&#xff1a; USACO&#xff08;美国信息学奥林匹克竞赛&#xff09;初次举办于1992年&#xff0c;其官网是美国一个著名在线题库&#xff0c;更是美国中学生的官方竞赛网站&#xff0c;开设目的是为每年夏季举办的国际信息学奥林匹克竞赛&#xff08;IOI&#xff09;…

深度学习——R-CNN目标检测原理

R-CNN系列算法需要先产生候选区域&#xff0c;再对候选区域做分类和位置坐标的预测&#xff0c;这类算法被称为两阶段目标检测算法。近几年&#xff0c;很多研究人员相继提出一系列单阶段的检测算法&#xff0c;只需要一个网络即可同时产生候选区域并预测出物体的类别和位置坐标…

开源C语言库Melon:I/O线程模型

本文展示开源C语言库Melon中的I/O线程模型。在Melon中存在三种线程模型&#xff0c;本篇仅对I/O线程模型进行说明。 关于 Melon 库&#xff0c;这是一个开源的 C 语言库&#xff0c;它具有&#xff1a;开箱即用、无第三方依赖、安装部署简单、中英文文档齐全等优势。 Github …

如何创建容器搭建节点

1.注册Discord账号 https://discord.com/这是登录网址&#xff1a; https://discord.com/ 2.点击startnow注册&#xff0c;用discord注册或者邮箱注册都可&#xff0c;然后登录tickhosting Tick Hosting这是登录网址&#xff1a;Tick Hosting 3.创建servers 4.点击你创建的s…

欧洲编程语言四巨头

从左往右&#xff0c;依次是 尼克劳斯沃斯 (Niklaus Wirth)&#xff0c;迪杰斯特拉&#xff08;Edsger Dijkstra&#xff09;&#xff0c;霍尔&#xff08;Tony Hoare&#xff09; 尼克劳斯沃斯 (Niklaus Wirth) 瑞士人&#xff0c;一生发明了8种编程语言&#xff0c;其中最著…

暖冬志愿服务在行动

1月7日&#xff0c;为了传递温暖与关爱&#xff0c;由雅安市群团中心指导&#xff0c;雅安市志愿服务联合会支持&#xff0c;雅安市雨城区梦飞翔公益社会服务中心执行的“暖冬志愿服务行动”在雨城区上里镇、碧峰峡镇、八步镇等乡镇&#xff0c;走访慰问困境儿童&#xff0c;为…

淘宝搜索指定店铺所有商品接口API调用介绍-含请求key代码示例

接口名称&#xff1a;item_search_shop 请求地址&#xff1a;taobao.item_search_shop 接口说明&#xff1a;此接口用于获取指定淘宝/天猫店铺的所有商品&#xff0c;通过传入shop_id或者seller_id可以获取到该店铺的所有商品&#xff0c;支持翻页展示。每页返回60个商品&…

1.4~1.5链表复习,代码操作(反转链表(用栈解决,双指针),删除链表指定元素),链表选择题,广义表

删除链表内指定范围的数 思路是双指针&#xff0c;定义两个指针&#xff0c;一个去找当前这个数满不满足要求&#xff0c;然后另一个定义为删除区间的起点 &#xff0c; 当不满足时&#xff0c;两个指针同时向后移动&#xff1b;当满足时&#xff0c;前驱指针就不动了&#xf…