Java實(shí)現(xiàn)單向鏈表反轉(zhuǎn)
更新時(shí)間:2018年03月10日 14:23:11 作者:hanxue1122
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)單向鏈表反轉(zhuǎn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本文實(shí)例為大家分享了Java實(shí)現(xiàn)單向鏈表反轉(zhuǎn)的具體代碼,供大家參考,具體內(nèi)容如下
1、實(shí)現(xiàn)代碼
public class LinkedListTest { public static void main(String[] args) { Node A = new Node("A"); Node B = new Node("B"); Node C = new Node("C"); Node D = new Node("D"); Node E = new Node("E"); Node F = new Node("F"); A.next = B; B.next = C; C.next = D; D.next = E; E.next = F; print(A); LinkedListReversor reversor = LinkedListReversor.RECURSION; System.out.println(reversor.getStrategy() + ":"); Node tmp = reversor.execute(A); print(tmp); reversor = LinkedListReversor.NO_RECURSION; System.out.println(reversor.getStrategy() + ":"); print(reversor.execute(tmp)); } private static void print(Node node) { while (node != null) { System.out.print(node.value); node = node.next; if (node != null) { System.out.print("->"); } else { System.out.println(); } } } } class Node { public String value; public Node next; public Node(String value) { this.value = value; } } enum LinkedListReversor { RECURSION("遞歸") { @Override public Node execute(Node node) { Node prev = null; if (node == null || node.next == null) { prev = node; } else { Node tmp = execute(node.next); node.next.next = node; node.next = null; prev = tmp; } return prev; } }, NO_RECURSION("非遞歸") { @Override public Node execute(Node node) { Node prev = null; while (node != null) { Node tmp = node; node = node.next; tmp.next = prev; prev = tmp; } return prev; } }; private String strategy; private LinkedListReversor(String strategy) { this.strategy = strategy; } public abstract Node execute(Node node); public String getStrategy() { return strategy; } }
2、實(shí)現(xiàn)思路
遞歸:從尾部開始處理
非遞歸:從頭部開始處理
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
java selenium Selenium IDE介紹及用法
本文主要介紹java selenium Selenium IDE,這里整理了相關(guān)資料和介紹如何安裝 Selenium IDE和使用方法,有需要的小伙伴可以參考下2016-08-08JAVA通過HttpClient發(fā)送HTTP請求的方法示例
本篇文章主要介紹了JAVA通過HttpClient發(fā)送HTTP請求的方法示例,詳細(xì)的介紹了HttpClient使用,具有一定的參考價(jià)值,有興趣的可以了解一下2017-09-09SpringBoot項(xiàng)目發(fā)送釘釘消息功能實(shí)現(xiàn)
在工作中的一些告警需要發(fā)送釘釘通知,有的是發(fā)給個(gè)人,有的要發(fā)到群里,這時(shí)項(xiàng)目就需要接入釘釘,實(shí)現(xiàn)發(fā)消息的功能,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-02-02MyBatis-plus使用lambda條件構(gòu)造器報(bào)錯(cuò)問題及解決
這篇文章主要介紹了MyBatis-plus使用lambda條件構(gòu)造器報(bào)錯(cuò)問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01