JAVA双向链表

1.链表是一种重要的数据结构,在程序设计中占有很重要的地位

2.我们可以用类List来实现链表结构,用变量Head、Tail、Length、Pointer来实现表头。存储当前结点的指针时有一定的技 巧,Pointer并非存储指向当前结点的指针,而是存储指向它的前趋结点的指针,当其值为null时表示当前结点是第一个结点。那么为什么要这样做呢? 这是因为当删除当前结点后仍需保证剩下的结点构成链表,如果Pointer指向当前结点,则会给操作带来很大困难。那么如何得到当前结点呢,我们定义了一 个方法cursor(),返回值是指向当前结点的指针。类List还定义了一些方法来实现对链表的基本操作,通过运用这些基本操作我们可以对链表进行各种 操作。例如reset()方法使第一个结点成为当前结点。insert(Object d)方法在当前结点前插入一个结点,并使其成为当前结点。remove()方法删除当前结点同时返回其内容,并使其后继结点成为当前结点,如果删除的是最 后一个结点,则第一个结点变为当前结点。

  1 /**
  2  * 双向链表的实现
  3  * @author Skip
  4  * @version 1.0
  5  */
  6 public class DoubleNodeList<T> {
  7  //节点类
  8  private static class Node<T>{
  9   Node<T> perv;  //前节点
 10   Node<T> next;  //后节点
 11   T data;    //数据
 12 
 13   public Node(T t){
 14    this.data = t;
 15   }
 16  }
 17  private Node<T> head;  //头节点
 18  private Node<T> last;  //尾节点
 19  private Node<T> other;  //备用节点存放临时操作
 20  private int length;  //链表长度
 21 
 22  /**
 23   * 无参构造
 24   */
 25  public DoubleNodeList(){
 26   head = new Node<T>(null);
 27   last = head;
 28   length = 0;
 29  }
 30 
 31  /**
 32   * 初始化时创建一个节点
 33   * @param data 数据
 34   */
 35  public DoubleNodeList(T data){
 36   head = new Node<T>(data);
 37   last = head;
 38   length = 1;
 39  }
 40 
 41  /**
 42   * 添加一个节点
 43   * @param data 添加的数据
 44   */
 45  public void add(T data){
 46   if(isEmpty()){
 47    head = new Node<T>(data);
 48    last = head;
 49    length++;
 50   }else{
 51    //尾插法
 52    other = new Node<T>(data);
 53    other.perv = last;
 54    last.next = other;
 55    last = other;
 56    length++;
 57   }
 58  }
 59 
 60  /**
 61   * 在指定数据后插入一个节点
 62   * @param data 指定的数据
 63   * @param insertData 插入的数据
 64   * @return 插入成功返回true,不成功返回false
 65   */
 66  public boolean addAfert(T data , T insertData){
 67   other = head;
 68   while(other != null){
 69    if(other.data.equals(data)){
 70     Node<T> t = new Node<T>(insertData);
 71     t.perv = other;
 72     t.next = other.next;
 73     other.next = t;
 74     //判断是否在最后一个节点后添加节点
 75     if(t.next==null){
 76      last = t;
 77     }
 78     length++;
 79     return true;
 80    }
 81    other = other.next;
 82   }
 83   return false;
 84  }
 85 
 86  /**
 87   * 在指定数据前插入一个节点
 88   * @param data 指定的数据
 89   * @param insertData 插入的数据
 90   * @return 插入成功返回true,不成功返回false
 91   */
 92  public boolean addBefore(T data, T insertData){
 93   other = head;
 94   while(other != null){
 95    if(other.data.equals(data)){
 96     Node<T> t = new Node<T>(insertData);
 97     t.perv = other.perv;
 98     t.next = other;
 99     other.perv.next = t;
100     length++;
101     return true;
102    }
103    other = other.next;
104   }
105   return false;
106  }
107 
108  /**
109   * 获得索引处的数据
110   * @param index 索引
111   * @return 数据
112   */
113  public T get(int index){
114   if(index>length || index<0){
115    throw new IndexOutOfBoundsException("索引越界:"+index);
116   }
117   other = head;
118   for(int i=0;i<index;i++){
119    other = other.next;
120   }
121   return other.data;
122  }
123 
124  /**
125   * 新值替换旧值
126   * @return 成功为true,未找到为false
127   */
128  public boolean set(T oldValue,T newValue){
129   other = head;
130   while(other!=null){
131    if(other.data.equals(oldValue)){
132     other.data = newValue;
133     return true;
134    }
135    other = other.next;
136   }
137   return false;
138  }
139 
140  /**
141   * 移除指定的元素
142   * @param data 需要移除的元素
143   * @return 不存在为false,成功为true
144   */
145  public boolean remove(T data){
146   other = head;
147   while(other != null){
148    if(other.data.equals(data)){
149     other.perv.next = other.next;
150     length--;
151     return true;
152    }
153    other = other.next;
154   }
155   return false;
156  }
157 
158  /**
159   * 链表中是否包含此元素
160   * @return 包含为true,不包含为false
161   */
162  public boolean contains(T data){
163   other = head;
164   while(other != null){
165    if(other.data.equals(data)){
166     return true;
167    }
168    other = other.next;
169   }
170   return false;
171  }
172 
173  /**
174   * 获得最后一个节点的数据
175   * @return 最后一个节点的数据
176   */
177  public T getLast(){
178   return last.data;
179  }
180 
181  /**
182   * 获得第一个节点的数据
183   * @return 第一个节点的数据
184   */
185  public T getFirst(){
186   return head.data;
187  }
188 
189  /**
190   * 获得链表的长度
191   * @return 长度
192   */
193  public int getSize(){
194   return length;
195  }
196 
197  /**
198   * 是否为空链表
199   * @return 空链表为true,非空链表为false
200   */
201  public boolean isEmpty(){
202   return length==0;
203  }
204 
205  /**
206   * 清空链表
207   */
208  public void clear(){
209   head = null;
210   length = 0;
211  }
212 
213  /**
214   * 输出链表内所有节点
215   */
216  public void printList(){
217   if(isEmpty()){
218    System.out.println("空链表");
219   }else{
220    other = head;
221    for(int i=0;i<length;i++){
222     System.out.print(other.data+" ");
223     other = other.next;
224    }
225    System.out.println();
226   }
227  }
228 }

 

posted @ 2016-08-12 22:04  点滴之水  阅读(517)  评论(0编辑  收藏  举报