线性表之ArrayList、LinkedList

一、线性表的特性

    线性表是按顺序存储数据时常用的一种数据结构,与规则集不同的是它可以存储重复的数字。下面是大多数线性表的一些典型操作:

1、从线性表中提取元素

2、向线性表中插入一个新元素

3、从线性表删除一个新元素

4、找出线性表中元素的个数

5、确定线性表中是否包含某个元素

6、判断线性表是否为空

    实现线性表的方式有两种,一种是使用数组存储线性表的元素。数组是动态创建的,如果元素超过数组的初始容量就创造一个更大的数组,然后把旧数组中的元素复制到新数组中。另外一种是使用链式结构。链接结构由结点组成,每个结点都是动态创建的,每个结点代表一个元素。

二、数组线性表ArrayList和链表类LinkedList

    两者都是实现了List接口,继承了AbsractList,非线程安全。如果需要用下标来随机访问元素,且除了在末尾不在其他位置进行插入、删除,用ArrayList是更为高效的选择。反之,则应该选择LinkedList。另外,在进行查询操作时,ArrayList相比LinkedList综合情况下要更高效。

ArrayList方法总结

1、add(int index, E element) //指定位置插入元素

2、add(E e) //添加元素到线性表末尾

3、addAll(Collection<? extends E> c) //在末尾添加c中所有元素

4、addAll(int index,Collection<? extends E> c) //在指定位置添加c中所有元素

5、clear() //删除列表中的所有元素

6、contains(Object o) //判断列表中是否有指定元素

7、get(int index) //获取指定下标的元素

8、 isEmpty() //判断是否为空

9、 remove(int index) //移除指定序号上的元素

10、remove(Object o) //移除指定元素

11、size() //返回列表元素个数

12、subList(int fromIndex, int toIndex) //返回指定范围的列表

LinkedList方法

和ArrayList不同的是LinkedList可以从头尾插入和删除元素且效率更高。

peek() //返回但不删除第一个元素

peekFirst() //返回但不删除第一个元素

peekLast() 返回但不删除最后一个元素

poll() //返回但删除第一个元素

pollFirst() //返回但删除第一个元素

pollLast() 返回但删除最后一个元素

注意点

在实际运用remove中遇到一个小问题,如下:

ArrayList list = new ArrayList();
for(int i = 1;i <11;i++){
	list.add(i);
}
list.remove(1);
list.remove(2);
list.remove(3);
System.out.println(list);

输出:

[1, 3, 5, 7, 8, 9, 10]

不是想象中的把序号为1、2、3的元素删掉,这是因为每次remove后返回的是删掉之后的元素列表,所以这个序号对应的是remove之后的,不是原来的了。

还有一点,当列表里面的元素也是数字时候,怎么判断传给remove的是序号还是元素?一种方法是把传入的元素加Integer包装类强制转换,因为当传入的是元素内容的时候参数必须是对象,而序号则是int基本类型。

list.remove((Integer)1);

ArrayList动态扩容问题

ArrayList有三个构造函数,分别是:

public ArrayList();
public ArrayList(Collection<? extends E> c);
public ArrayList(int initialCapacity) ;

    在没有指定初始容量的时候,默认调用的是无参构造函数,这时候初始容量是10。但是这种分配容量并不是在调用的时候发生,而是发生在第一次add添加元素之后。如果在进行业务操作之前已经确定需要大量空间,那么使用有参构造函数或者无参构造函数加ensurCapacity在保证最低分配的容量是有必要的,这样可以避免频繁扩容导致的效率低下。

ArrayList每次扩容后的大小为之前大小的1.5倍。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ArrayListLinkedList的区别主要有以下几点: 1. 数据结构:ArrayList是基于动态数组实现的,而LinkedList是基于链表实现的。ArrayList的底层是一个可以动态修改的数组,没有固定大小的限制,可以随意添加或删除元素。而LinkedList则是一种线性表,数据并不按线性顺序存储,而是在每个节点里存储下一个节点的地址。 2. 随机访问和插入/删除操作的效率:由于底层数据结构的不同,ArrayList在随机访问(通过索引获取元素)和设置操作(修改指定索引位置的元素)方面更高效,因为它可以直接通过索引来定位元素。而LinkedList在插入和删除操作方面更高效,因为它只需要修改节点的指针即可,不需要像ArrayList那样重新分配内存空间。 3. 时间复杂度:由于数据结构的差异,ArrayList在随机访问和设置操作方面的时间复杂度为O(1),即常数时间。而LinkedList在这些操作方面的时间复杂度为O(n),其中n是链表的长度。然而,在插入和删除操作方面,ArrayList的时间复杂度为O(n),因为需要移动元素来保持连续性,而LinkedList的时间复杂度为O(1),因为只需要修改指针。 总结起来,ArrayList适用于需要频繁进行随机访问和修改操作的场景,而LinkedList适用于需要频繁进行插入和删除操作的场景。在选择使用ArrayList还是LinkedList时,需要根据具体的需求和操作进行权衡和选择。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [java集合框架05——ArrayListLinkedList的区别](https://blog.csdn.net/eson_15/article/details/51145788)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [JavaArrayListLinkedList区别](https://download.csdn.net/download/weixin_38722464/13758804)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [ArrayListLinkedList 的区别](https://blog.csdn.net/ltq2030/article/details/123637681)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值