一、线性表的特性
线性表是按顺序存储数据时常用的一种数据结构,与规则集不同的是它可以存储重复的数字。下面是大多数线性表的一些典型操作:
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倍。