线性表之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倍。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值