如何在Java中反轉單鏈表?
在本文中,我將向您展示如何在沒有遞迴的情況下在Java中反轉單個連結串列。單鏈表,也稱為連結串列,是一組節點,只能在一個方向上遍歷,例如向前。連結串列中的每個節點都包含兩個內容,一個數據和指向列表中下一個節點的指標。為了反轉連結串列,我們需要遍歷列表,在每一步我們都需要反轉連結,例如在第一次迭代之後,head將指向null,而next元素將指向head。在到達連結串列尾部時遍歷結束時,尾部將指向第二個最後一個元素,它將成為一個新頭,因為您可以遍歷此節點中的所有元素。
因為我們不能使用java.util.LinkedList來演示這個例子,因為它是一個雙向連結串列。在雙向連結串列中,您可以在兩個方向上進行遍歷,即向前和向後遍歷,因為每個節點都包含對前一個節點和下一個節點的引用。請參閱Thomas H. Cormen的“演算法簡介”中的良好資料結構和演算法手冊,以瞭解有關連結串列資料結構的更多資訊。
對於這個例子,我建立了我們自己的單鏈表類。與java.util.LinkedList類似,它還包含一個巢狀的靜態類Node,它表示連結列表的節點。它包含一個整數屬性來儲存資料部分,另一個Node引用指向列表中的下一個。如果要建立通用連結列表,則應將int替換為泛型型別T,如此處所示。
為了證明我們的反向方法有效,我們不僅要建立連結串列,還要填充連結串列。為了填充,我們需要在單鏈表上實現add()方法。你有兩個選擇,要麼在頭部或尾部新增元素,要新增元素是很容易的,因為它不需要遍歷直到結束但是如果你想建立一個包含按順序排列元素的列表新增然後我們需要在連結串列的末尾新增節點。
我還建立了一個print()方法來列印單個連結串列的所有節點,用空格分隔。此方法非常有用,可以證明我們的反向方法是否正常工作,因為您可以在反轉之前和之後列印連結串列。
無遞迴單鏈表的Java程式
這是我們的示例程式,演示如何在Java中反轉連結串列。為了逆轉,我首先建立了一個名為singlylinkedlist的類,它表示一個連結串列資料結構。我進一步實現了add()和print()方法,將元素新增到連結列表中,並按向前順序列印。
反向連結列表的邏輯封裝在reverse()方法中。它從頭部到尾部遍歷連結列表,並在每個步驟中反轉連結,例如,每個節點而不是指向開始指向上一個節點的下一個元素,這樣,當到達最後一個元素時,整個連結列表將反轉,然後該元素將成為連結列表的新頭部。
<b>package</b> test; <font><i>/** * Java Program to reverse a singly list without using recursion. */</i></font><font> <b>public</b> <b>class</b> LinkedListProblem { <b>public</b> <b>static</b> <b>void</b> main(String[] args) { </font><font><i>// creating a singly linked list</i></font><font> SinglyLinkedList.Node head = <b>new</b> SinglyLinkedList.Node(1); SinglyLinkedList linkedlist = <b>new</b> SinglyLinkedList(head); </font><font><i>// adding node into singly linked list</i></font><font> linkedlist.add(<b>new</b> SinglyLinkedList.Node(2)); linkedlist.add(<b>new</b> SinglyLinkedList.Node(3)); </font><font><i>// printing a singly linked list</i></font><font> linkedlist.print(); </font><font><i>// reversing the singly linked list</i></font><font> linkedlist.reverse(); </font><font><i>// printing the singly linked list again</i></font><font> linkedlist.print(); } } </font><font><i>/** * A class to represent singly list in Java * * @author WINDOWS 8 * */</i></font><font> <b>class</b> SinglyLinkedList { <b>static</b> <b>class</b> Node { <b>private</b> <b>int</b> data; <b>private</b> Node next; <b>public</b> Node(<b>int</b> data) { <b>this</b>.data = data; } <b>public</b> <b>int</b> data() { <b>return</b> data; } <b>public</b> Node next() { <b>return</b> next; } } <b>private</b> Node head; <b>public</b> SinglyLinkedList(Node head) { <b>this</b>.head = head; } </font><font><i>/** * Java method to add an element to linked list * @param node */</i></font><font> <b>public</b> <b>void</b> add(Node node) { Node current = head; <b>while</b> (current != <b>null</b>) { <b>if</b> (current.next == <b>null</b>) { current.next = node; <b>break</b>; } current = current.next; } } </font><font><i>/** * Java method to print a singly linked list */</i></font><font> <b>public</b> <b>void</b> print() { Node node = head; <b>while</b> (node != <b>null</b>) { System.out.print(node.data() + </font><font>" "</font><font>); node = node.next(); } System.out.println(</font><font>""</font><font>); } </font><font><i>/** * Java method to reverse a linked list without recursion */</i></font><font> <b>public</b> <b>void</b> reverse() { Node pointer = head; Node previous = <b>null</b>, current = <b>null</b>; <b>while</b> (pointer != <b>null</b>) { current = pointer; pointer = pointer.next; </font><font><i>// reverse the link</i></font><font> current.next = previous; previous = current; head = current; } } } Output 1 2 3 3 2 1 </font>
您可以看到連結列表已反轉,前面的1是第一個元素,現在是最後一個元素,而3是連結列表或頭的第一個元素。
所有這些都是關於如何在Java中不使用遞迴來反轉單鏈表。這個解決方案中沒有使用遞迴,而是使用迭代。您可以看到reverse()方法中的while迴圈。