Java数据结构-模拟ArrayList集合思想,手写底层源码(1),底层数据结构是数组,编写add添加方法

package com.atguigu.structure;
public class Demo02_arrayList {public static void main(String[] args) {MyGenericArrayListV1 arrayListV1 = new MyGenericArrayListV1();//arr.add(element:100,index:1);下标越界,无法插入//初始化(第一次添加)  elements=[0,0,0,0,0]  size=0//第二次添加前  elements=[10,0,0,0,0]   size=1//第三次添加前  elements=[10,20,0,0,0]  size=2arrayListV1.add(10, 0);arrayListV1.add(20, 1);arrayListV1.add(30, 2);//打印前  elements=[10,20,30,0,0]  size=3arrayListV1.print();//10 20 30 0 0//10 20 30 0 0 elements=[10,20,30,0,0]  size=3}
}
class MyGenericArrayListV1{//组织存储数据的结构private int[] elements;//数据关系的属性//The size of the ArrayList (the number of elements it contains)//ArrayList集合的大小(包含元素的数量)private int size;public MyGenericArrayListV1() {this(5);}public MyGenericArrayListV1(int capacity) {elements = new int[capacity];size = 0;}//操作数据的方法://1、新增:根据下标插入数据、头插 、 尾插public void add(int element, int index) {//参数1:要新增的数据   参数2:要插入的位置下标//第一次添加 element=10   index=0    size=0//第二次添加 element=20   index=1    size=1//第三次添加 element=30   index=2    size=2if (isFull()) {System.out.println("数组已满,无法插入");return;}//数组数据是连续存储的,不能跳过未存储数据的位置//第一次添加   index=0  size=0   element=10   elements=[0,0,0,0,0]//第二次添加   index=1  size=1   element=20   elements=[10,0,0,0,0]//第三次添加   index=2  size=2   element=30   elements=[10,20,0,0,0]if (index<0||index>size) {System.out.println("下标越界,无法插入");return;}//如果新增时,数组中没有元素,添加到第一个索引位置 直接存入//如果位置上已存在元素 当前索引位置旧元素需要往后移动//[1,2,3,4,0]  => 将 5 插入到索引为 index(1) 的位置 [1,5,2,3,4]  ==>设置5到索引1位置//[1,2,3,0,0]  => 将 5 插入到索引为 index(1) 的位置 [1,5,2,3,0]  ==>设置5到索引1位置//判断要存入的位置是否需要移动元素//第一次添加  index=0  size=0  i=size-1=-1>0 -1>不大于0 所以循环进不去,不用移动元素//第二次添加  index=1  size=1  i=size-1=0>1  0不大于1 所以循环进不去,不用移动元素//第三次添加  index=2  size=2  i=size-1=1>2  1不大于2 所以循环进不去,不用移动元素for (int i = size - 1; i >= index; i--) {elements[i + 1] = elements[i];}//第一次添加前   element=10   index=0    elements=[0,0,0,0,0]//第一次添加后   element=10   index=0    elements=[10,0,0,0,0]//第二次添加前   element=20   index=1    elements=[10,0,0,0,0]//第二次添加后   element=20   index=1    elements=[10,20,0,0,0]//第三次添加前   element=30   index=2    elements=[10,20,0,0,0]//第三次添加后   element=30   index=2    elements=[10,20,30,0,0]elements[index] = element;//第一次添加  size=0 变成 size=1  element=10  index=0//第二次添加  size=1 变成 size=2  element=20  index=1//第三次添加  size=2 变成 size=3  element=30  index=2size++;}//2、删除//3、修改//4、查询//辅助方法:新增数据时size++,移除数据时size--//是否为空public boolean isEmpty() {//size=3return size == 0;}//是否已满public boolean isFull() {//第一次添加    elements=[0,0,0,0,0]  size=0    elements.length=5//第二次添加    elements=[10,0,0,0,0]  size=1   elements.length=5 //第三次添加    elements=[10,20,0,0,0]  size=2  elements.length=5return size == this.elements.length;}//正序打印public void print() {//elements.length=5     elements=[10,20,30,0,0]if (isEmpty()) {return;}//elements=[10,20,30,0,0]  elements.length=5  for (int i = 0; i < this.elements.length; i++) {//第一次循环  i=0  elements=[10,20,30,0,0]  elements[i]=10  elements.length=5//第二次循环  i=1  elements=[10,20,30,0,0]  elements[i]=20  elements.length=5//第三次循环  i=2  elements=[10,20,30,0,0]  elements[i]=30  elements.length=5//第四次循环  i=3  elements=[10,20,30,0,0]  elements[i]=0  elements.length=5//第五次循环  i=4  elements=[10,20,30,0,0]  elements[i]=0  elements.length=5System.out.print(this.elements[i] + "\t");}System.out.println();}//反序打印public void printRev() {if (isEmpty()) {return;}int length = this.elements.length;while (--length >= 0) {//第一次使用数组长度-1,当做下标取最后一个位置的元素打印//第二次使用长度-2System.out.println(this.elements[length]+"\t");}System.out.println();}}

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

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

相关文章

PWM实现蜂鸣器

tim4.h #ifndef __TIM4_H__ #define __TIM4_H__ #include "stm32mp1xx_rcc.h" #include "stm32mp1xx_gpio.h" #include "stm32mp1xx_tim.h" void timer4_init();#endif tim4.c #include "tim4.h"void timer4_init() {// 1. 设置GPI…

头部首发优志愿头部u_sign生成与TLS指纹处理! + 数据可视化技术讲解【Python爬虫】

目录 针对大学名称 大学排名, 综合指数,学校情况等数据进行爬取 找对应得数据包 请求发现数据有加密 发现加密参数 搜索加密参数&#xff0c;好进行分析 分析过程 数据可视化 针对大学名称 大学排名, 综合指数,学校情况等数据进行爬取 首先进行鼠标右键&#xff0c;进行…

如何预防[[MyFile@waifu.club]].wis [[backup@waifu.club]].wis勒索病毒感染您的计算机?

导言&#xff1a; 近期&#xff0c;一种新兴的威胁[[MyFilewaifu.club]].wis [[backupwaifu.club]].wis勒索病毒&#xff0c;引起了广泛关注。这种恶意软件通过其高度复杂的加密算法&#xff0c;威胁着用户和组织的数据安全。本文将深入介绍[[MyFilewaifu.club]].wis [[backup…

(7)Linux GDB以及gcc和g++

&#x1f4ad; 前言 本章我们将带着大家高雅的学一学令众多习惯图形化页面的朋友难受的 gdb 调试&#xff0c;这部分知识可以选择性学习学习&#xff0c;以后倘若遇到一些问题时能在 Linux 内简单调试&#xff0c;还是很香的。然后在讲讲 gcc 和 g&#xff0c;系统讲解程序运行…

​C语言顺序查找算法以及代码​

通过前面对静态查找表的介绍&#xff0c;静态查找表即为只做查找操作的查找表。静态查找表既可以使用顺序表表示&#xff0c;也可以使用链表结构表示。虽然一个是数组、一个链表&#xff0c;但两者在做查找操作时&#xff0c;基本上大同小异。 本节以静态查找表的顺序存储结构为…

【Spring】11 EnvironmentAware 接口

文章目录 1. 简介2. 作用3. 使用3.1 创建并实现接口3.2 配置 Bean 信息3.3 创建启动类3.4 启动 4. 应用场景总结 Spring 框架为开发者提供了丰富的扩展点&#xff0c;其中之一就是 Bean 生命周期中的回调接口。本文将着重介绍一个与环境&#xff08;Environment&#xff09;相关…

Atcoder Beginner Contest 332 (A - F 题)

目录 [A - Online Shopping](https://atcoder.jp/contests/abc332/tasks/abc332_a)Problem StatementConstraintsInputOutputSample Input 1Sample Output 1Sample Input 2Sample Output 2Sample Input 3Sample Output 3 SolutionCode [B - Glass and Mu](https://atcoder.jp/c…

Crocoddyl: 多接触最优控制的高效多功能框架

系列文章目录 前言 我们介绍了 Crocoddyl&#xff08;Contact RObot COntrol by Differential DYnamic Library&#xff09;&#xff0c;这是一个专为高效多触点优化控制&#xff08;multi-contact optimal control&#xff09;而定制的开源框架。Crocoddyl 可高效计算给定预定…

太阳能供电+4G摄像头搭建EasyCVR鱼塘养殖远程视频监控方案

一、背景需求 随着我国农业的快速发展&#xff0c;以及对新兴技术的应用&#xff0c;养殖业、农牧业、种植业等也面临着全新的挑战与机遇。对鱼塘养殖行业来说&#xff0c;养殖区域面积大、管理难&#xff0c;经常会遇到偷钓者、盗窃鱼苗、非法入侵等监管难题。在国家大力扶持…

2023年OceanBase开发者大会-核心PPT资料下载

一、峰会简介 2023年OceanBase开发者大会主要涵盖了OceanBase的最新技术进展、产品更新以及开发者工具的发布。大会发布了OceanBase 4.1版本&#xff0c;公布了两大友好工具&#xff0c;升级了文档的易用性&#xff0c;并统一了企业版和社区版的代码分支。这些举措全面呈现了O…

基于局域网和广域网训练推理加速策略

一、基于局域网的多GPU上并行训练 TensorFlow 的 MirroredStrategy 和 PyTorch 的 DistributedDataParallel 它们可以帮助您在多个 GPU 或多个计算节点上训练大型模型。这些策略的核心目标是提高训练速度,同时保持模型的准确性和稳定性。 加速的底层原理 TensorFlow 的 Mirro…

一文教会pandas

今天的笔试题令我感触很深&#xff0c;回顾一下之前写的都是低代码想想都。。。 anareport[[reportid,anndt,stockid]].drop_duplicates().rolling(window10,min_periods1).sum().groupby([anndt,stockid])[reportid].count() dfanareport[[reportid,anndt,stockid]].drop_dup…

构建高效持久层:深度解析 MyBatis-Plus(02)

目录 引言1. 逻辑删除1.1 概述1.2 逻辑删除的优势1.3.为什么使用逻辑删除1.4 综合案例 2. 乐观锁和悲观锁2.1.什么是乐观锁和悲观锁2.2.乐观锁和悲观锁的区别2.3.综合案例 3. 分页插件总结 引言 在现代软件开发中&#xff0c;数据库操作是不可或缺的一环。为了提高系统的性能、…

awk统计日志

部分日志文本格式内容 [2023-12-18 22:40:52.301][INFO ][221][com.excellent.common.core.security.filter.UrlRedirectFilter.doFilter:131] ----------------->>> 请求进入拦截器&#xff0c;IP&#xff1a;14.111.199.218, CLIENT&#xff1a;ANDROID&#xff0c…

避坑指南:uni-forms表单在uni-app中的实践经验

​&#x1f308;个人主页&#xff1a;前端青山 &#x1f525;系列专栏&#xff1a;uni-app篇 &#x1f516;人终将被年少不可得之物困其一生 依旧青山,本期给大家带来JavaScript篇专栏内容:uni-app中forms表单的避坑指南篇 该篇章已被前端圈子收录,点此处进入即可查看更多优质内…

计算机网络考研辨析(后续整理入笔记)

文章目录 体系结构物理层速率辨析交换方式辨析编码调制辨析 链路层链路层功能介质访问控制&#xff08;MAC&#xff09;信道划分控制之——CDMA随机访问控制轮询访问控制 扩展以太网交换机 网络层网络层功能IPv4协议IP地址IP数据报分析ICMP 网络拓扑与转发分析&#xff08;重点…

阶段十-springsecurity总结

jwt认证流程 SpringSecurity 认证过程 第一步&#xff1a; 创建一个类实现UserDetailsService接口&#xff0c;重写其中的方法 通过重写 public UserDetails loadUserByUsername(String username) 方法 从数据库校验用户输入的用户名 配置SecurityConfig Bean注入 Passwor…

类中成员函数及普通函数地址获取方式

文章目录 代码准备测试演示注意事项成员函数类型申明测试演示总的打印输出 代码准备 头文件:Calc.h #pragma onceclass Calc { public:int add(int,int);//函数声明static int sub(int,int);//函数声明 public:int b;//定义了一个成员变量static int a;//声明了一个静态成员变…

SG3524控制的恒流源电路图

SG3524简介 SG3524是开关电源脉宽调制型控制器。应用于开关稳压器&#xff0c;变压器耦合的直流变换器&#xff0c;电压倍增器&#xff0c;极性转换器等。采用固定频率&#xff0c;脉冲宽度调制&#xff08;脉宽调制&#xff09;技术。输出允许单端或推挽输出。芯片电路包括电…

lvs负载均衡

lvs负载均衡群集 群集 特点&#xff1a;由多台主机构成&#xff0c;都干同一件事&#xff0c;对外显示一个整体 企业集群分类 负载均衡群集高可用群集高性能运算群集 负载均衡群集&#xff08;LB&#xff09; 负载均衡的作用 提高应用系统的响应能力可以处理更多的访问请…