Java学习之数据结构篇-------ArrayList

这篇博客探讨了Java中的ArrayList数据结构,强调其作为动态数组的特点,支持对象类型存储及增删改查操作。文章指出ArrayList的随机访问优势,并提醒读者在按元素值删除时需注意类型匹配。此外,作者分享了两个使用ArrayList时遇到的问题:1) 在存储连续整数序列时,由于浅拷贝导致原有序列被修改,解决方案是使用ArrayList的构造函数创建副本。2) 当元素为整型时,按值删除和按下标删除可能导致混淆,建议将整型元素封装为Integer对象后再进行操作。
摘要由CSDN通过智能技术生成
基本概念
  1. 动态数组,可以增加动态增加容量
  2. 添加的元素为对象类型
  3. 包括增删改查的操作
  4. 可以随机访问,有按下标访问
  5. 删除元素有两种类型,按下标和按元素值两种;按元素值删除时,应严格保证元素类型
应用ArrayList的出错总结:
  1. 问题1

在剑指offer的JZ41题,应用穷举法列举和为S的连续整数序列时,序列结果存储在一个ArrayList<ArrayList>中, 出现的错误:

当用ArrayList<Integer>存储一个整数序列时,不能直接加入最终所有序列的结果ArrayList<ArrayList>中,因为记录下一个整数序列时,结果集中的原序列也会被改变,即ArrayList<ArrayList>中存放的ArrayList<Integer>是浅拷贝的形式,会被改变。

解决方案: 可以用ArrayList的构造方法,添加一个指定集合的构造对象。

  1. 问题2

ArrayList 可以按下标删除元素,也可以按元素值删除元素
当元素为整型时,两者会冲突。
所以当元素为整型时,删除元素时应该进行对象封装,转为Integer类型;

ArrayList<Integer> a = new ArrayList<>();
a.add(2);
a.add(3);
a.add(1)

a.remove((Integer)1); //删除后数组中还有2,3
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值