package ArrayList;
/**
* <p>MyArrayList是个动态数组,初始容量为10的空列表</p>
* <p>在添加大量元素前,应用程序可以使用 ensureCapacity 操作来增加 ArrayList 实例的容量.这可
* 以减少递增式再分配的数量</p>
* @author baby69yy2000
*/
public class MyArrayList<T> {
private T[] listArr;
private int listSize;
/**
* 构造一个初始容量为10的空列表
*/
public MyArrayList() {
listArr = (T[]) new Object[10];
listSize = 0;
}
/**
* <p>方法ensureCapacity是MyArrayList类实现的一个重要操作, 它提供了允许ArrayList对象
* 进行动态增长的存储空间管理工具</p>
* <p>在MyArrayList对象的大小等于其容量时, 分配一个更大的数组, 并将已有值复制到新数组中</p>
* @param minCapacity 所需的最小容量
*/
public void ensureCapacity(int minCapacity) {
int currentCapacity = listArr.length;
if(minCapacity > currentCapacity) {
T[] oldlistArr = listArr;
listArr = (T[]) new Object[minCapacity];
for (int i = 0; i < listSize; i++) {
listArr[i] = oldlistArr[i];
}
oldlistArr = null;
}
}
/**
* 将此 MyArrayList 实例的容量调整为列表的当前大小
*/
public void trimToSize() {
int oldCapacity = listArr.length;
if(listSize < oldCapacity) {
T[] oldlistArr = listArr;
listArr = (T[]) new Object[listSize];
for (int i = 0; i < listSize; i++) {
listArr[i] = oldlistArr[i];
}
oldlistArr = null;
}
}
/**
* MyArrayList的连接
* 把listB放到listA的末尾
*/
public static <T> void joinList(MyArrayList<T> listA, MyArrayList<T> listB) {
int sizeA = listA.size(), sizeB = listB.size();
listA.ensureCapacity(sizeA + sizeB);
for(int i = 0; i < sizeB; i++)
listA.add(listB.get(i));
}
/**
* 求listArr的长度
* @return listArr长度
*/
public int listArrLength() {
return listArr.length;
}
/**
* 数组下标越界检查函数
*/
private void rangeCheck(int index, String s, int upperBound) {
if(index < 0 || index >= upperBound + 1) {
throw new IndexOutOfBoundsException("\n" + s + ": index" + index +
"out of bounds. Should be in the range 0 to " + upperBound);
}
}
/**
* 将指定的元素插入此列表中的指定位置.向右移动当前位于该位置的元素(如果有)以及所有后续元素
* (将其索引加 1)
* @param index 指定元素所插入位置的索引
* @param item 要插入的元素
* @throws IndexOutOfBoundsException
*/
public void add(int index, T item) {
rangeCheck(index, "MyArrayList add()", listSize);
if(listSize == listArr.length)
ensureCapacity(2*listArr.length);
for(int j = listSize - 1; j >= index; j--)
listArr[j + 1] = listArr[j];
listArr[index] = item;
listSize++;
}
/**
* 将指定的元素追加到此列表的尾部
* @param item 要追加到此列表中的元素
*/
public boolean add(T item) {
add(listSize, item);
return true;
}
/**
* 返回列表中首次出现指定元素的索引
* @param item 要搜索的元素
* @return 返回列表中手册出现指定元素的索引,如果列表不包含该元素,则返回 -1
*/
public int indexOf(T item) {
int i = 0;
int last = listSize - 1;
while(i <= last && listArr[i] != item) i++;
if(i > last) return -1;
else return i;
}
/**
* 移除此列表中指定位置上的元素. 向左移动所有后续元素(将其索引减 1)
* @param index 要移除的元素的索引
* @return 从列表中移除的元素
* @throws IndexOutOfBoundsException
*/
public T remove(int index) {
rangeCheck(index, "MyArrayList remove()", listSize - 1);
T returnElement = listArr[index];
for (int j = index; j < listSize - 1; j++)
listArr[j] = listArr[j + 1];
listArr[listSize - 1] = null;
listSize--;
return returnElement;
}
/**
* 移除列表中出现的首个指定元素
* @param item 要从此列表中移除的元素(如果存在)
* @return 如果此列表包含指定的元素,则返回 true
*/
public boolean remove(T item) {
int i = 0;
boolean returnValue = true;
if((i = indexOf(item)) != -1)
remove(i);
else
returnValue = false;
return returnValue;
}
/**
* 如果此列表中包含指定的元素,则返回 true
* @param item 要测试列表中是否存在的元素
* @return 如果列表包含指定的元素,则返回 true
*/
public boolean contains(T item) {
return indexOf(item) >=0;
}
/**
* 返回此列表中指定位置上的元素
* @param index 所返回元素的索引
* @return 此列表中指定位置上的元素
*/
public T get(int index) {
rangeCheck(index, "MyArrayList get()", listSize - 1);
return listArr[index];
}
/**
* 用指定的元素替代此列表中指定位置上的元素
* @param index 要替代的元素的索引
* @param item 指定的元素
* @return 以前位于该指定位置上的元素
*/
public T set(int index, T item) {
T oldValue = listArr[index];
listArr[index] = item;
return oldValue;
}
/**
* 返回一个按照正确的顺序包含此列表中所有元素的数组
* @return 一个按照正确的顺序包含此列表中所有元素的数组
*/
public Object[] toArray() {
Object[] result = new Object[listSize];
//System.arraycopy(listArr, 0, result, 0, listSize);
for (int i = 0; i < listSize; i++) {
result[i] = listArr[i];
}
return result;
}
/**
* 反转列表
*/
public void reverse() {
T temp;
int size = this.size();
for(int i = 0, j = listSize - 1, mid = size>>1; i < mid; i++, j--) {
temp = listArr[i];
listArr[i] = listArr[j];
listArr[j] = temp;
}
}
/**
* 返回此列表中的元素数
* @return 此列表中的元素数
*/
public int size() {
return listSize;
}
/**
* 测试此列表中是否有元素
* @return 如果此列表中没有元素,则返回 true;否则返回 false
*/
public boolean isEmpty() {
return listSize == 0;
}
/**
* 移除此列表中的所有元素
*/
public void clear() {
for (int i = 0; i < listSize; i++)
listArr[i] = null;
listSize = 0;
}
public static void main(String[] args) {
MyArrayList<String> listA = new MyArrayList<String>();
MyArrayList<String> listB = new MyArrayList<String>();
//mal.ensureCapacity(100);
listA.add("A");
listA.add("B");
listA.add("C");
listA.add("D");
listA.add("E");
listA.reverse();
//listB.add("F");
//listB.add("G");
//listA.joinList(listA, listB);
//listA.reverse();
for (int i = 0; i < listA.size(); i++) {
System.out.println(listA.get(i));
}
/*Object[] s = mal.toArray();
for (int i = 0; i < s.length; i++) {
System.out.println(s[i].toString());
}*/
//mal.trimToSize();
/*System.out.println(mal.listArrLength()); // 4
System.out.println(mal.size()); // 4
mal.clear();
System.out.println(mal.listArrLength()); // 4
System.out.println(mal.size());*/ // 0
/*mal.add(new Point(2, 3));
mal.add(new Point(8, 9));
Object[] objs = mal.toArray();
for (int i = 0; i < objs.length; i++) {
System.out.println(objs[i]);
}*/
/*System.out.println(mal.indexOf("C")); // 2
System.out.println(mal.indexOf("E")); // -1
System.out.println(mal.contains("A")); // true
System.out.println(mal.remove("B"));
mal.add(2, "BB");
for (int i = 0; i < mal.size(); i++) {
System.out.println(mal.get(i));
}
System.out.println(mal.isEmpty());
System.out.println(mal.remove("B"));
System.out.println(mal.size());*/
}
}
class Point {
int x, y;
public Point(int x, int y) {
this.x = x;
this.y = y;
}
public String toString() {
return "x = " + x + " y = " + y;
}
}
分享到:
相关推荐
修炼成Javascript中级程序员必知必会_资源分享
内容概要:本文详细介绍了如何使用MATLAB的深度学习工具箱,在果树病虫害识别任务中从数据准备、模型设计、训练优化到最后的模型评估与应用全流程的具体实施步骤和技术要点。涵盖了MATLAB深度学习工具箱的基本概念及其提供的多种功能组件,如卷积神经网络(CNN)的应用实例。此外,文中还具体讲述了数据集的收集与预处理方法、不同类型的深度学习模型搭建、训练过程中的超参数设定及其优化手段,并提供了病虫害识别的实际案例。最后展望了深度学习技术在未来农业领域的潜在影响力和发展前景。 适合人群:对深度学习及农业应用感兴趣的科研人员、高校师生和相关从业者。 使用场景及目标:①希望掌握MATLAB环境下构建深度学习模型的方法和技术细节;②从事果树病虫害管理研究或实践,寻找高效的自动化解决方案。 阅读建议:在阅读本文之前,建议读者熟悉基本的MATLAB编程环境及初步了解机器学习的相关概念。针对文中涉及的理论和技术难点,可以通过官方文档或其他教程进行补充学习。同时,建议动手实践每一个关键点的内容,在实践中加深理解和掌握技能。
nodejs010-nodejs-block-stream-0.0.7-1.el6.centos.alt.noarch.rpm
机械模型与技术交底书的融合:创新点详解与解析,机械模型加技术交底书,有创新点 ,机械模型; 技术交底书; 创新点,创新机械模型与技术交底书详解
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
nodejs010-nodejs-cmd-shim-1.1.0-4.1.el6.centos.alt.noarch.rpm
西门子四轴卧加后处理系统:828D至840D兼容,四轴联动高效加工解决方案,支持图档处理及试看程序。,西门子四轴卧加后处理,支持828D~840D系统,支持四轴联动,可制制,看清楚联系,可提供图档处理试看程序 ,核心关键词:西门子四轴卧加后处理; 828D~840D系统支持; 四轴联动; 制程; 联系; 图档处理试看程序。,西门子四轴卧加后处理程序,支持多种系统与四轴联动
基于黏菌优化算法(SMA)的改进与复现——融合EO算法更新策略的ESMA项目报告,黏菌优化算法(SMA)复现(融合EO算法改进更新策略)——ESMA。 复现内容包括:改进算法实现、23个基准测试函数、多次实验运行并计算均值标准差等统计量、与SMA对比等。 程序基本上每一步都有注释,非常易懂,代码质量极高,便于新手学习和理解。 ,SMA复现;EO算法改进;算法实现;基准测试函数;实验运行;统计量;SMA对比;程序注释;代码质量;学习理解。,标题:ESMA算法复现:黏菌优化与EO算法融合改进的实证研究
基于MATLAB的Stewart平台并联机器人仿真技术研究与实现:Simscape环境下的虚拟模拟分析与应用,MATLAB并联机器人Stewart平台仿真simscape ,MATLAB; 并联机器人; Stewart平台; 仿真; Simscape; 关键技术。,MATLAB中Stewart平台并联机器人Simscape仿真
Grad-CAM可视化医学3D影像
探索comsol泰勒锥:电流体动力学的微观世界之旅,comsol泰勒锥、电流体动力学 ,comsol泰勒锥; 电流体动力学; 锥形结构; 电场影响,COMSOL泰勒锥与电流体动力学研究
免费JAVA毕业设计 2024成品源码+论文+数据库+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
PFC6.03D模型动态压缩模拟与SHPB霍普金森压杆系统理论及实验数据处理技术解析,PFC6.03D模型,动态压缩模拟,还包括: SHPB霍普金森压杆系统理论知识介绍,二波法和三波法处理实验数据,提出三波波形,计算动态压缩强度等 ,PFC模型; 动态压缩模拟; SHPB霍普金森压杆系统; 理论介绍; 二波法处理; 三波法处理; 三波波形; 动态压缩强度。,"PFC模型下的动态压缩模拟及SHPB理论实践研究"
ProASCI 开发板原理图,适用于A3P3000
免费JAVA毕业设计 2024成品源码+论文+录屏+启动教程 启动教程:https://www.bilibili.com/video/BV1SzbFe7EGZ 项目讲解视频:https://www.bilibili.com/video/BV1Tb421n72S 二次开发教程:https://www.bilibili.com/video/BV18i421i7Dx
1、文件内容:pykde4-devel-4.10.5-6.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/pykde4-devel-4.10.5-6.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装
基于Comsol模拟的三层顶板随机裂隙浆液扩散模型:考虑重力影响的瞬态扩散规律分析,Comsol模拟,考虑三层顶板包含随机裂隙的浆液扩散模型,考虑浆液重力的影响,模型采用的DFN插件建立随机裂隙,采用达西定律模块中的储水模型为控制方程,分析不同注浆压力条件下的浆液扩散规律,建立瞬态模型 ,Comsol模拟; 随机裂隙浆液扩散模型; 浆液重力影响; DFN插件; 达西定律模块储水模型; 注浆压力条件; 浆液扩散规律; 瞬态模型,Comsol浆液扩散模型:随机裂隙下考虑重力的瞬态扩散分析
A simple fast, easy use distributed file system written by golang(similar fastdfs).go-fastdfs
手机编程-1738391552157.jpg