当前位置: 首页 > news >正文

ArrayList集合方法(自写)

以下方法在使用时需要new一个新对象调用,输出时需要一个输出方法,否则输出的是地址

1.最后位置插入

//最后位置插入
public void add(int element){if (size>=arr.length){capacity*=factor;int[] temp=new int[capacity];for (int i = 0; i <arr.length ; i++) {temp[i]=arr[i];}arr=temp;}arr[size]=element;size++;}

2.任意位置插入         

//在任意位置插入//value 插入的值//index 插入的位置public void insert(int value,int index){if (index<0||index>size){System.out.println("插入位置不合理");return;}if (size== arr.length){//扩容capacity*=factor;int[] temp=new int[capacity];for (int i = 0; i <arr.length ; i++) {temp[i]=arr[i];}arr=temp;}//插入位置以及插入位置以后的数据往后移动for (int i =size-1; i >=index ; i--) {arr[i+1]=arr[i];}//插入数据arr[index]=value;size++;}

3.删除第一个复合条件的元素

 //删除第一个复合条件的数据public boolean delFirst(int value){boolean isFound=false;for (int i = 0; i < size ; i++) {if(arr[i]==value){//删除for (int j = i; j <size-1 ; j++) {arr[j]=arr[j+1];}size--;isFound=true;break;}}return isFound;}

4.删除所有复合条件的元素 

//删除所有复合条件的数据public boolean delete(int value){boolean isFound=false;//从后往前遍历可以删除两个相邻的复合条件的数据for (int i = size-1; i >=0 ; i--) {if(arr[i]==value){//删除for (int j = i; j <size-1 ; j++) {arr[j]=arr[j+1];}size--;isFound=true;}}return isFound;}

5.在合适位置插入 

//在合适位置插入public void orderInsert(int value){if (size== arr.length){//扩容capacity*=factor;int[] temp=new int[capacity];for (int i = 0; i <arr.length ; i++) {temp[i]=arr[i];}arr=temp;}//插入if(size==0){arr[0]=value;}else if(value>arr[size-1]){arr[size]=value;}else {for (int i = 0; i <size ; i++) {if(arr[i]>value){//插入位置以及之后的数据往后移动for (int temp=size-1;temp>=i;temp--){arr[temp+1]=arr[temp];}arr[i]=value;break;}}}size++;}

6.二分查找 

//二分查找public int search(int value){int left=0;int right=size;while (left<=right){int mid=(left+right)/2;if(arr[mid]==value){System.out.println("找到了,下标为"+mid);return mid;}else if(arr[mid]>value){right=mid-1;}else {left=mid+1;}}System.out.println("没找到");return -1;}

 

http://www.lryc.cn/news/223459.html

相关文章:

  • sql注入学习笔记
  • 企业涉密文件怎么加密?企业重要文件加密方法
  • 经典猜数游戏(python类封装)
  • 环形链表~
  • GZ038 物联网应用开发赛题第1套
  • SQL关键字
  • 第三章:人工智能深度学习教程-基础神经网络(第五节-了解多层前馈网络)
  • 如何实现Debian工控电脑USB接口安全管控
  • 开源知识库软件xwiki在Windows下的安装
  • 学习c#的第一天
  • 机器学习实战——《跟着迪哥学Python数据分析与机器学习实战》
  • 开源的全能维护 U 盘工具:Ventoy
  • Redis7学习笔记01
  • Redis的持久化机制和配置
  • 【IP固定】地平线开发板如何实现重启IP地址不变
  • CHATGPT----自然辩证法分析
  • Python测试框架之pytest快速入门
  • CSS 动画特效运用目录
  • css文本溢出省略号点点点
  • MSSQL 配置ORACLE ​链接服务器
  • HiSilicon352 android9.0 适配红外遥控器
  • 0004Java安卓程序设计-springboot基于APP的鲜花商城
  • 对Axios进行封装
  • Python TCP服务端多线程接收RFID网络读卡器上传数据
  • Ubuntu22.04安装MySql
  • 设计模式-桥接模式(Bridge)
  • 库存预占架构升级方案设计-交易库存中心
  • 【redis】ssm项目整合redis,redis注解式缓存及应用场景,redis的击穿、穿透、雪崩的解决方案
  • chatGPT对英语论文怎么润色呢?
  • 【机器学习4】降维