您好,登錄后才能下訂單哦!
這篇文章給大家介紹Java中怎么定義一個簡單鏈表,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
一、概述:
1、原理:
只有一個數據項(鏈接點Link),每個數據插入時都是對第一個數據的引用。
2、插入數據說明:
當鏈表沒有數據時,插入的值就是第一個數據,如果鏈表里有數據,就把當前的數據的next指針指向第一個數據。
3、插入數據圖:
4、特點:先進后出
5、實現功能:
數據插入,指定位置插入,顯示,查詢,刪除等
6、刪除原理
7、插入頭節點原理
二、實現:
1、創建節點
/** * @描述 節點 * @項目名稱 Java_DataStruct * @包名 com.struct.linklist * @類名 Node * @author chenlin * @date 2010年6月26日 上午7:58:59 * @version 1.0 */ public class Node { public long data; public Node next; public long getData() { return data; } public void display(){ System.out.print(data + " "); } public Node(long data) { this.data = data; } public void setData(long data) { this.data = data; } public Node getNext() { return next; } public void setNext(Node next) { this.next = next; } }
2、鏈表實現
/** * @描述 鏈表 * @項目名稱 Java_DataStruct * @包名 com.struct.linklist * @類名 LinkList * @author chenlin * @date 2010年6月26日 上午8:00:28 * @version 1.0 */ public class LinkList { private Node first; public LinkList(){ first = null; } /** * 插入數據 * @param value */ public void insertFirst(long value){ Node newNode = new Node(value); if (first == null) { first = newNode; }else { //把first節點往下移動 newNode.next = first; //把插入的節點作為新的節點 first = newNode; } } /** * 刪除頭節點 * @param value * @return */ public Node deleteFirst(){ if (first == null) { throw new RuntimeException("鏈表數據不存在"); } Node temp = first; first = temp.next; return temp; } public Node deleteByKey(long key){ Node current = first; Node last = first; while(current.data != key){ if (current.next == null) { System.out.println("沒找到節點"); return null; } last = current; current = current.next; } if (current == first) { //return deleteFirst(); //指向下個就表示刪除第一個 first = first.next; }else { last.next = current.next; } return current; } /** * 顯示所有的數據 */ public void display(){ if (first == null) { //throw new RuntimeException("鏈表數據不存在"); return; } Node current = first; while(current != null){ current.display(); current = current.next; } System.out.println("---------------"); } /** * 查找節點1 * @param value * @return */ public Node findByValue(long value){ Node current = first; while(current != null){ if (current.data != value) { current = current.next; }else { break; } } if (current == null) { System.out.println("沒找到"); return null; } return current; } /** * 查找節點2 * * @param key * @return */ public Node findByKey(long key) { Node current = first; while (current.data != key) { if (current.next == null) { System.out.println("沒找到"); return null; } current = current.next; } return current; } /** * 根據索引查找對應的值 * @param position * @return */ public Node findByPosition(int position){ Node current = first; //為什么是position - 1,因為要使用遍歷,讓current指向下一個, 所以position - 1的下個node就是要找的值 for (int i = 0; i < position - 1 ; i++) { current = current.next; } return current; } public static void main(String[] args) { LinkList linkList = new LinkList(); linkList.insertFirst(21); linkList.insertFirst(22); linkList.insertFirst(23); linkList.insertFirst(24); linkList.insertFirst(25); linkList.insertFirst(26); linkList.insertFirst(27); System.out.println("億速云測試結果:"); linkList.display(); System.out.println("---查找-------------------------------------"); linkList.findByKey(25).display(); System.out.println("--刪除first-------------------------------------"); //linkList.deleteFirst().display(); ///linkList.deleteFirst().display(); //linkList.deleteFirst().display(); //linkList.deleteFirst().display(); System.out.println("-刪除指定值---------------------------------------"); linkList.deleteByKey(27).display(); linkList.deleteByKey(21).display(); System.out.println("----------------------------------------"); linkList.display(); } }
顯示結果:
關于Java中怎么定義一個簡單鏈表就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。