数据结构的Java实现——顺序表

来源:互联网 发布:java petstore 编辑:程序博客网 时间:2024/06/04 18:27

顺序表: 线性表的顺序表是,指的是用一组地址连续的存储单元一次存储线性表的数据元素。以元素在计算机内“物理位置相邻”来表示线性表中数据元素之间的逻辑关系。只要确定了存储线性表的起始位置,线性表中任何一数据元素都可以随机存取,所以线性表的存储结构是一种随机存取的存储结构。

由于高级程序设计语言中的数组类型也具有随机存取的特性,因此,通常都用数组来描述数据结构中的顺序存储结构。

优点——随机存储,读取数据的速度快

缺点——顺序存储,当需要增加、删除数据是慢

 

 

[java] view plaincopy
  1. package ds.linerlist;  
  2. /** 
  3.  * 顺序表的实现 
  4.  * @author Bao Yiming 
  5.  * @param <E> 
  6.  */  
  7. public class ArrayList<E> {  
  8.     private Object[] data = null// data: 用来保存此线性表数据的数组  
  9.     private int capacity; // capacity: 线性表的容量  
  10.     private int current; // current: 当前数据的下标  
  11.     /** 
  12.      * 初始化为声明大小,则设置为10。 
  13.      */  
  14.     ArrayList() {  
  15.         this(10);  
  16.     }  
  17.     /** 
  18.      * 初始化线性表,声明保存数据的数组大小。 
  19.      * @param initialSize 顺序表的初始化大小 
  20.      */  
  21.     ArrayList(int initialSize) {  
  22.         if (initialSize >= 0) {  
  23.             this.capacity = initialSize;  
  24.             data = new Object[initialSize];  
  25.             current = 0;  
  26.         } else {  
  27.             throw new RuntimeException("初始化大小不能小于0:" + initialSize);  
  28.         }  
  29.     }  
  30.     /** 
  31.      * 在线性表的末尾添加元素,添加之前确认线性表是否已满 
  32.      * @param e 待加入的元素 
  33.      * @return 
  34.      */  
  35.     public boolean AddElement(E e) {  
  36.         ensureCapacity();  
  37.         data[current] = e;  
  38.         ++current;  
  39.         return true;  
  40.     }  
  41.     /** 
  42.      * 检查存储数据的数组容量,如果数组已经满,则扩充容量;否则不操作。 
  43.      */  
  44.     private void ensureCapacity() {  
  45.         int index;  
  46.         if (current == capacity) {  
  47.             capacity *= 2;  
  48.             Object[] newData = new Object[capacity];  
  49.             for(index = 0; index < current; ++index) {  
  50.                 newData[index] = data[index];  
  51.             }  
  52.             data = newData;  
  53.         }  
  54.     }  
  55.     /** 
  56.      * 返回下标为index的元素 
  57.      * @param index 欲取得元素的下标 
  58.      * @return 
  59.      */  
  60.     public E get(int index) {  
  61.         validateIndex(index);  
  62.         return (E) data[index];  
  63.     }  
  64.     /** 
  65.      *  
  66.      * @param index 待插入的位置 
  67.      * @param e 待插入的元素 
  68.      * @return 
  69.      */  
  70.     public boolean set(int index, E e) {  
  71.         validateIndex(index);  
  72.         data[index] = e;  
  73.         return true;  
  74.     }  
  75.     /** 
  76.      * 验证下标值是否合法,非法时抛出异常 
  77.      * @param index 待验证的下标值 
  78.      */  
  79.     private void validateIndex(int index) {  
  80.         if (index < 0 || index > current) {  
  81.             throw new RuntimeException("无效的下标:" + index);  
  82.         }  
  83.     }  
  84.     /** 
  85.      * 返回当前顺序表的大小 
  86.      * @return 
  87.      */  
  88.     public int size() {  
  89.         return current;  
  90.     }  
  91.     /** 
  92.      * 在指定位置插入指定元素 
  93.      * @param index 待插入的位置 
  94.      * @param e 待插入的元素 
  95.      * @return 
  96.      */  
  97.     public boolean insert(int index, E e) {  
  98.         validateIndex(index);  
  99.         ensureCapacity();  
  100.         for (int temp = current; temp > index; --temp) {  
  101.             data[temp] = data[temp - 1];  
  102.         }  
  103.         data[index] = e;  
  104.         return true;  
  105.     }  
  106.     /** 
  107.      * 删除下标为index元素 
  108.      * @param index 待删除元素的下标 
  109.      * @return 
  110.      */  
  111.     public boolean delete(int index) {  
  112.         validateIndex(index);  
  113.         for ( ; index < current - 1; ++index) {  
  114.             data[index] = data[index + 1];  
  115.         }  
  116.         data[current - 1] = null;  
  117.         --current;  
  118.         return true;  
  119.     }  
  120.     @Override  
  121.     public String toString() {  
  122.         String str = "[ ";  
  123.         for (Object o : data) {  
  124.             if (o != null) {  
  125.                 str += o + " ";  
  126.             }  
  127.         }  
  128.         str += "]";  
  129.         return str;  
  130.     }  
  131. }   

0 0
原创粉丝点击