1. 程式人生 > >java LinkedList的使用方法介紹

java LinkedList的使用方法介紹

LinkedList類是雙向列表,列表中的每個節點都包含了對前一個和後一個元素的引用.
LinkedList的建構函式如下
1. public LinkedList():  ——生成空的連結串列
2. public LinkedList(Collection col):  複製建構函式
1、獲取連結串列的第一個和最後一個元素
  1. import java.util.LinkedList;  
  2. publicclass LinkedListTest{  
  3.   publicstaticvoid main(String[] args) {  
  4.     LinkedList<String> lList = new
     LinkedList<String>();  
  5.     lList.add("1");  
  6.     lList.add("2");  
  7.     lList.add("3");  
  8.     lList.add("4");  
  9.     lList.add("5");  
  10.     System.out.println("連結串列的第一個元素是 : " + lList.getFirst());  
  11.     System.out.println("連結串列最後一個元素是 : " + lList.getLast());  
  12.   }  
  13. }  

2、獲取連結串列元素  
  1. for (String str: lList) {  
  2.       System.out.println(str);  
  3.     }  
3、從連結串列生成子表
  1. List subl = lList.subList(14);  
  2.     System.out.println(subl);  
  3.     lst.remove(2);  
  4.     System.out.println(lst);  
  5.     System.out.println(lList);  
4、新增元素:新增單個元素
 如果不指定索引的話,元素將被新增到連結串列的最後.
public boolean add(Object element)
public boolean add(int index, Object element)
也可以把連結串列當初棧或者佇列來處理:
public boolean addFirst(Object element)
public boolean addLast(Object element)
addLast()方法和不帶索引的add()方法實現的效果一樣.
  1. import java.util.LinkedList;  
  2. publicclass LinkedListTest{  
  3.   publicstaticvoid main(String[] a) {  
  4.     LinkedList list = new LinkedList();  
  5.     list.add("A");  
  6.     list.add("B");  
  7.     list.add("C");  
  8.     list.add("D");  
  9.     list.addFirst("X");  
  10.     list.addLast("Z");  
  11.     System.out.println(list);  
  12.   }  
  13. }  
5、刪除元素
  1. public Object removeFirst()  
  2. public Object removeLast()  
  3. import java.util.LinkedList;  
  4. publicclass MainClass {  
  5.   publicstaticvoid main(String[] a) {  
  6.     LinkedList list = new LinkedList();  
  7.     list.add("A");  
  8.     list.add("B");  
  9.     list.add("C");  
  10.     list.add("D");  
  11.     list.removeFirst();  
  12.     list.removeLast();  
  13.     System.out.println(list);  
  14.   }  
  15. }  
6、使用連結串列實現棧效果
  1. import java.util.LinkedList;  
  2. publicclass MainClass {  
  3.   publicstaticvoid main(String[] args) {  
  4.     StackL stack = new StackL();  
  5.     for (int i = 0; i < 10; i++)  
  6.       stack.push(i);  
  7.     System.out.println(stack.top());  
  8.     System.out.println(stack.top());  
  9.     System.out.println(stack.pop());  
  10.     System.out.println(stack.pop());  
  11.     System.out.println(stack.pop());  
  12.   }  
  13. }  
  14. class StackL {  
  15.   private LinkedList list = new LinkedList();  
  16.   publicvoid push(Object v) {  
  17.     list.addFirst(v);  
  18.   }  
  19.   public Object top() {  
  20.     return list.getFirst();  
  21.   }  
  22.   public Object pop() {  
  23.     return list.removeFirst();  
  24.   }  
  25. }  
7、使用連結串列來實現佇列效果
  1. import java.util.LinkedList;  
  2. publicclass MainClass {  
  3.   publicstaticvoid main(String[] args) {  
  4.     Queue queue = new Queue();  
  5.     for (int i = 0; i < 10; i++)  
  6.       queue.put(Integer.toString(i));  
  7.     while (!queue.isEmpty())  
  8.       System.out.println(queue.get());  
  9.   }  
  10. }  
  11. class Queue {  
  12.   private LinkedList list = new LinkedList();  
  13.   publicvoid put(Object v) {  
  14.     list.addFirst(v);  
  15.   }  
  16.   public Object get() {  
  17.     return list.removeLast();  
  18.   }  
  19.   publicboolean isEmpty() {  
  20.     return list.isEmpty();  
  21.   }  
  22. }  

8、將LinkedList轉換成ArrayList

  1. ArrayList<String> arrayList = new ArrayList<String>(linkedList);  
  2.     for (String s : arrayList) {  
  3.       System.out.println("s = " + s);  
  4.     }  
9、刪掉所有元素:清空LinkedList
    lList.clear();
10、刪除列表的首位元素
  1. import java.util.LinkedList;  
  2. publicclass Main {  
  3.   publicstaticvoid main(String[] args) {  
  4.     LinkedList<String> lList = new LinkedList<String>();  
  5.     lList.add("1");  
  6.     lList.add("2");  
  7.     lList.add("3");  
  8.     lList.add("4");  
  9.     lList.add("5");  
  10.     System.out.println(lList);  
  11.         //元素在刪除的時候,仍然可以獲取到元素
  12.     Object object = lList.removeFirst();  
  13.     System.out.println(object + " has been removed");  
  14.     System.out.println(lList);  
  15.     object = lList.removeLast();  
  16.     System.out.println(object + " has been removed");  
  17.     System.out.println(lList);  
  18.   }  
  19. }  
11、根據範圍刪除列表元素
  1. import java.util.LinkedList;  
  2. publicclass Main {  
  3.   publicstaticvoid main(String[] args) {  
  4.     LinkedList<String> lList = new LinkedList<String>();  
  5.     lList.add("1");  
  6.     lList.add("2");  
  7.     lList.add("3");  
  8.     lList.add("4");  
  9.     lList.add("5");  
  10.     System.out.println(lList);  
  11.     lList.subList(25).clear();  
  12.     System.out.println(lList);  
  13.   }  
  14. }  
12、刪除連結串列的特定元素
  1. import java.util.LinkedList;