リンクリストでよく使われる操作 - 反転の詳細な説明

零下一度
リリース: 2017-07-19 13:40:50
オリジナル
2034 人が閲覧しました

リンク リストでよく使用される操作 - 反転

まず、単一リンク リストのノード クラスを定義しましょう

public class ListNode {2         
int val;3         ListNode next = null;// 指向的下个节点4 5         
ListNode(int val) {6             this.val = val;7         }8     
}
ログイン後にコピー

単一リンク リストの反転を実装するには 2 つの方法があります

1。後ろから前へ。先頭ノードから開始して、末尾ノードが見つかるまで逆方向に検索し、その後、逆方向に進みます。

 1     public ListNode reverseList(ListNode head) { 2         
 if (head == null || head.next == null) 3             return head; 4  5         
 ListNode prev = reverseList(head.next);// 递归调用,先反转下个节点 6  7         
 head.next.next = head;// 将当前结点的指针域指向前一结点 8         
 head.next = null;// 前一结点的指针域令为null; 9         
 return prev;// 反转后新链表的头结点10     
 }
ログイン後にコピー

2. トラバースを使用して、前から後ろに反転します。まず次のノードを保存し、次に現在のノードを前のノードにポイントし、ノードを下に移動して次の反転のサイクルを継続します。

 1     public ListNode reverseList(ListNode head) { 2         if (head == null) { 3             
 return null; 4         } 5         ListNode pre = null; 6         
 ListNode next = null; 7         while (head != null) { 8             
 // 保存下个节点,防止丢失 9             next = head.next;10             
 // 将他的下个节点指向前个节点11             head.next = pre;12 13             
 // head指向pre后,就继续依次反转下个节点14             
 // 让pre,head依次向后移动一个节点,继续下一次的反转15             
 pre = head;16             head = next;17         }18         
 return pre;19     
 }
ログイン後にコピー

オンラインプログラミングを終了し、将来簡単に参照できるように記録しました。

以上がリンクリストでよく使われる操作 - 反転の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!