欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實現(xiàn)單鏈表反轉(zhuǎn)的多種方法總結(jié)

 更新時間:2021年04月12日 10:33:35   作者:起個花名好難  
這篇文章主要給大家介紹了關(guān)于Java實現(xiàn)單鏈表反轉(zhuǎn)的多種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

對于單鏈表不熟悉的可以看一下基于Java實現(xiàn)單鏈表的增刪改查

一、原地反轉(zhuǎn)

1、新建一個哨兵節(jié)點下一結(jié)點指向頭結(jié)點

2、把待反轉(zhuǎn)鏈表的下一節(jié)點插入到哨兵節(jié)點的下一節(jié)點

反轉(zhuǎn)之前的鏈表:1–>2–>3–>4>–>5

加入哨兵節(jié)點:dummp–>1–>2–>3–>4>–>5

原地反轉(zhuǎn):

定義:prev=dummp.next; pcur=prev.next;

prev.next=pcur.next;

pcur.next=dummp.next;

dummp.next=pcur;

pcur=prev.next;

public Stu_node reverse_list(Stu_node head){
        if (head.next==null ||head.next.next==null)
            return null;
        Stu_node dump = new Stu_node(-1," ");
        dump.next=head;
        Stu_node prev = dump.next;
        Stu_node pcur = prev.next;
        while(pcur!=null){
            prev.next=pcur.next;
            pcur.next=dump.next;
            dump.next=pcur;
            pcur=prev.next;
        }
        return dump.next;
    }

二、新建鏈表頭結(jié)點插法

二、新建鏈表頭結(jié)點插法:

新建一個頭結(jié)點,遍歷原鏈表,把每個節(jié)點用頭結(jié)點插入到新建鏈表中。最后,新建的鏈表就是反轉(zhuǎn)后的鏈表。

public Stu_node reverse_list1 (Stu_node head){
        //新建一個新的鏈表的頭結(jié)點
        Stu_node dump = new Stu_node(-1," ");
        Stu_node pcur = head;
        //遍歷待反轉(zhuǎn)鏈表,頭結(jié)點插入到新的鏈表中
        while(pcur!=null){
            Stu_node pnext = pcur.next;
            pcur.next = dump.next;
            dump.next=pcur;
            pcur=pnext;
        }
        //新鏈表頭結(jié)點不是需要返回的數(shù)據(jù),因此返回頭結(jié)點的下一節(jié)點
        return dump.next;
    }

三、利用棧結(jié)構(gòu)實現(xiàn)鏈表的反轉(zhuǎn)

由于棧結(jié)構(gòu)存儲數(shù)據(jù)是先進(jìn)后出(后進(jìn)先出)也可以通過棧達(dá)到反轉(zhuǎn)鏈表的目的。

 public Stu_node reverse_stack(Stu_node head){
        Stack<Stu_node> stack = new Stack<>();
        Stu_node temp = head;
        //鏈表入棧
        while(temp!=null){
            stack.push(temp);
            temp=temp.next;
        }
        //取出棧中的一個節(jié)點當(dāng)做新的鏈表的頭結(jié)點
        Stu_node new_head = stack.pop();
        Stu_node cur = new_head;
        //出站
        while(!stack.isEmpty()){
            Stu_node node = stack.pop();
            //將出站的節(jié)點指向取消
            node.next=null;
            //將新的鏈表串起來
            cur.next = node;
            cur = node;
        }
        return new_head;
    }

四、完整代碼奉上

import java.util.Stack;

public class revere_node {
    public static void main(String[] args) {
        LinkedNode list= new LinkedNode();
        Stu_node node1 = new Stu_node(1,"張三");
        Stu_node node2 = new Stu_node(2,"李四");
        Stu_node node3 = new Stu_node(3,"王二");
        Stu_node node4 = new Stu_node(4,"麻子");
        Stu_node node5 = new Stu_node(5,"趙六");
        //打印添加節(jié)點之前的鏈表
        list.print();
        //尾結(jié)點添加節(jié)點
        list.add(node1);
        list.add(node2);
        list.add(node3);
        list.add(node4);
        list.add(node5);
        //打印添加加點之后的鏈表
        list.print();
        System.out.println("-------------------");
        //定義一個頭結(jié)點接收調(diào)用函數(shù)返回的頭節(jié)點
        Stu_node head = list.reverse_stack(list.head);
        //遍歷輸出每個節(jié)點
        while (head.next!=null){
            System.out.println(head);
            head=head.next;
        }

    }
}
//定義一個鏈表的操作類
class LinkedNode{
    //定義一個頭結(jié)點
    Stu_node head = new Stu_node(-1," ");
    //添加鏈表的方法
    public void add(Stu_node node){
        Stu_node temp = head;
        while(true){
            if (temp.next==null)
                break;
            temp=temp.next;
        }
        temp.next=node;
    }
    //打印鏈表
    public void print(){
        Stu_node temp = head.next;
        if (head.next==null){
            System.out.println("此鏈表為空");
        }
        while (temp!=null){
            System.out.println(temp);
            temp=temp.next;
        }
    }
    //原地反轉(zhuǎn)
    public Stu_node reverse_list(Stu_node head){
        if (head.next==null ||head.next.next==null)
            return null;
        Stu_node dump = new Stu_node(-1," ");
        dump.next=head;
        Stu_node prev = dump.next;
        Stu_node pcur = prev.next;
        while(pcur!=null){
            prev.next=pcur.next;
            pcur.next=dump.next;
            dump.next=pcur;
            pcur=prev.next;
        }
        return dump.next;
    }
    //新建一個新的鏈表,頭結(jié)點插入法實現(xiàn)鏈表的反轉(zhuǎn)
    public Stu_node reverse_list1 (Stu_node head){
        Stu_node dump = new Stu_node(-1," ");
        Stu_node pcur = head;
        while(pcur!=null){
            Stu_node pnext = pcur.next;
            pcur.next = dump.next;
            dump.next=pcur;
            pcur=pnext;
        }
        return dump.next;
    }
    //利用棧實現(xiàn)反轉(zhuǎn)鏈表
    public Stu_node reverse_stack(Stu_node head){
        Stack<Stu_node> stack = new Stack<>();
        Stu_node temp = head;
        //鏈表入棧
        while(temp!=null){
            stack.push(temp);
            temp=temp.next;
        }
        //取出一個節(jié)點當(dāng)做新的鏈表的頭結(jié)點
        Stu_node new_head = stack.pop();
        Stu_node cur = new_head;
        //出站
        while(!stack.isEmpty()){
            Stu_node node = stack.pop();
            //將出站的節(jié)點指向取消
            node.next=null;
            //將新的鏈表串起來
            cur.next = node;
            cur = node;
        }
        return new_head;
    }
}
//節(jié)點類
class Stu_node{
    int num;
    String name;
    Stu_node next;
    //重寫toString方法,顯示節(jié)點數(shù)據(jù)
    @Override
    public String toString() {
        return "Stu_node{" +
                "num=" + num +
                ", name='" + name + '\'' +
                '}';
    }

    public Stu_node(int num, String name) {
        this.num = num;
        this.name = name;
    }
}

總結(jié)

到此這篇關(guān)于Java實現(xiàn)單鏈表反轉(zhuǎn)的多種方法的文章就介紹到這了,更多相關(guān)Java單鏈表反轉(zhuǎn)方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • ReentrantLock從源碼解析Java多線程同步學(xué)習(xí)

    ReentrantLock從源碼解析Java多線程同步學(xué)習(xí)

    這篇文章主要為大家介紹了ReentrantLock從源碼解析Java多線程同步學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • Java如何通過反射獲取私有構(gòu)造、私有對象、私有字段、私有方法

    Java如何通過反射獲取私有構(gòu)造、私有對象、私有字段、私有方法

    這篇文章主要介紹了Java如何通過反射獲取私有構(gòu)造、私有對象、私有字段、私有方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-12-12
  • 簡單了解JAVA內(nèi)存泄漏和溢出區(qū)別及聯(lián)系

    簡單了解JAVA內(nèi)存泄漏和溢出區(qū)別及聯(lián)系

    這篇文章主要介紹了簡單了解JAVA內(nèi)存泄漏和溢出區(qū)別及聯(lián)系,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-03-03
  • Java讓多線程按順序執(zhí)行的幾種方法

    Java讓多線程按順序執(zhí)行的幾種方法

    本文主要介紹了Java讓多線程按順序執(zhí)行的幾種方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • 使用java.util.Timer實現(xiàn)任務(wù)調(diào)度

    使用java.util.Timer實現(xiàn)任務(wù)調(diào)度

    這篇文章主要為大家詳細(xì)介紹了使用java.util.Timer實現(xiàn)任務(wù)調(diào)度,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • java封裝的概念和實現(xiàn)方法示例

    java封裝的概念和實現(xiàn)方法示例

    這篇文章主要介紹了java封裝的概念和實現(xiàn)方法,結(jié)合實例形式詳細(xì)分析了java封裝的概念、原理及相關(guān)使用技巧,需要的朋友可以參考下
    2019-11-11
  • java理論基礎(chǔ)Stream元素的匹配與查找

    java理論基礎(chǔ)Stream元素的匹配與查找

    這篇文章主要為大家介紹了java理論基礎(chǔ)Stream元素的匹配與查找方法的示例說明解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-03-03
  • Java中List add添加不同類型元素的講解

    Java中List add添加不同類型元素的講解

    今天小編就為大家分享一篇關(guān)于java的List add不同類型的對象,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • spring cloud-給Eureka Server加上安全的用戶認(rèn)證詳解

    spring cloud-給Eureka Server加上安全的用戶認(rèn)證詳解

    這篇文章主要介紹了spring cloud-給Eureka Server加上安全的用戶認(rèn)證詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Java基礎(chǔ)入門之switch怎么使用枚舉

    Java基礎(chǔ)入門之switch怎么使用枚舉

    在Java開發(fā)中,switch語句是一種常用的流控制語句,而當(dāng)使用枚舉類型作為條件時,我們常常會遇到報錯問題,那么該如何解決呢,下面就來詳細(xì)講講
    2023-06-06

最新評論