如何實現單鏈表的增刪操做

Java程序員面試筆試寶典P232勘誤,程序有BUG!!!程序員

  1 /**
  2  * Created by ahu_lichang on 2017/7/25.
  3  */
  4 //結點類
  5 class Node{
  6     Node next = null;
  7     int data;
  8     public Node(int data){
  9         this.data = data;
 10     }
 11 }
 12 public class HuaWeiOJTest {
 13     //鏈表頭的引用
 14     Node head = null;
 15     //插入元素
 16     public void addNode(int d){
 17         Node newNode = new Node(d);
 18         if(head == null){
 19             head = newNode;
 20             return;
 21         }
 22         Node tmp = head;
 23         while (tmp.next!=null){
 24             tmp = tmp.next;
 25         }
 26         tmp.next = newNode;
 27     }
 28     //刪除元素
 29     public Boolean deleteNode(int index){
 30         if(index<1 || index>length()){
 31             return false;
 32         }
 33         if(index == 1){//刪除第一個元素
 34             head = head.next;
 35             return true;
 36         }
 37         int i=2;//由於第一個元素已經判斷過了!因此這裏從第二個元素開始就好。若是這裏從第一個開始的話,會有BUG!!!(源程序:int i=1;)
 38         Node preNode = head;
 39         Node curNode = preNode.next;
 40         while (curNode!=null){
 41             if(i == index){
 42                 preNode.next = curNode.next;
 43                 return true;
 44             }
 45             preNode = curNode;
 46             curNode = curNode.next;
 47             i++;
 48         }
 49         return true;
 50     }
 51     //結點的長度
 52     public int length(){
 53         int length = 0;
 54         Node tmp = head;
 55         while (tmp!=null){
 56             length++;
 57             tmp=tmp.next;
 58         }
 59         return length;
 60     }
 61     //對鏈表節點進行排序,從小到大.返回頭結點
 62     public Node orderList(){
 63         Node nextNode = null;
 64         int temp = 0;
 65         Node curNode = head;
 66         while (curNode.next!=null){
 67             nextNode = curNode.next;
 68             while (nextNode!=null){
 69                 if(curNode.data>nextNode.data){
 70                     temp = curNode.data;
 71                     curNode.data = nextNode.data;
 72                     nextNode.data = temp;
 73                 }
 74                 nextNode = nextNode.next;
 75             }
 76             curNode = curNode.next;
 77         }
 78         return head;
 79     }
 80     //打印鏈表
 81     public void printList(){
 82         Node tmp = head;
 83         while (tmp!=null){
 84             System.out.println(tmp.data);
 85             tmp = tmp.next;
 86         }
 87     }
 88 
 89     public static void main(String[] args){
 90         HuaWeiOJTest list = new HuaWeiOJTest();
 91         list.addNode(5);
 92         list.addNode(3);
 93         list.addNode(1);
 94         list.addNode(3);
 95         list.deleteNode(4);//刪除第四個元素
 96         System.out.println(list.length());
 97         list.printList();
 98         list.orderList();
 99         System.out.println("----------------");
100         list.printList();
101     }
102 
103 }

相關文章
相關標籤/搜索