亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java如何實現(xiàn)單鏈表的增刪改查

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

一、新建學(xué)生節(jié)點類

Stu_Node節(jié)點包含:

學(xué)號:int num;

姓名:String name;

性別:String gender;

下一個節(jié)點:Stu_Node next;

為了便于打印節(jié)點內(nèi)容需要重寫toString方法

class Stu_Node{
    int num;
    String name;
    String gender;
    Stu_Node next;

    @Override
    public String toString() {
        return "Stu_Node{" +
                "num=" + num +
                ", name='" + name + '\'' +
                ", gender='" + gender + '\'' +
                '}';
    }
    public Stu_Node(int num, String name, String gender){
        this.num=num;
        this.name=name;
        this.gender=gender;
    }
}

二、新建一個操作鏈表的類,實現(xiàn)增刪改查方法

1>創(chuàng)建鏈表的實現(xiàn)類對象

class SingleLinkedList{

}

2>在類里實現(xiàn)尾結(jié)點添加鏈表節(jié)點方法

1、定義一個頭結(jié)點head為空。

2、定義一個節(jié)點變量temp等于頭結(jié)點head。

3、遍歷鏈表找到尾結(jié)點。

while循環(huán),結(jié)束的標(biāo)志是temp的下一個節(jié)點為空,此時終止while(否則程序會陷入死循環(huán)),循環(huán)每進行一次要把temp節(jié)點的下一個節(jié)點賦值給temp變量(否則程序會陷入死循環(huán))。

4、使temp節(jié)點的下一個節(jié)點指向新增的節(jié)點。

class SingleLinkedList{
    Stu_Node head = new Stu_Node(0,"null","null");
    //鏈表的尾節(jié)點添加方法
    public void add(Stu_Node node){
        Stu_Node temp = head;
        while(true){
            if (temp.next==null){
                break;
            }
            temp = temp.next;
        }
        temp.next=node;
    }
    
}

按學(xué)號順序插入節(jié)點

1、新建臨時節(jié)點temp

2、新建boolean變量flag用于找到當(dāng)前帶插入節(jié)點的位置

3、while循環(huán)遍歷鏈表找到插入節(jié)點位置,如果temp的下一節(jié)點為空表示鏈表已經(jīng)遍歷完畢此時終止循環(huán);如果temp的下一節(jié)點的學(xué)號等于要插入的節(jié)點學(xué)號,此時將flag變量賦值為true結(jié)束循環(huán)(帶插入的節(jié)點已經(jīng)存在插入失敗);如果temp節(jié)點的下一節(jié)點的學(xué)號大于帶插入節(jié)點的學(xué)號,此時temp下一節(jié)點指向的位置就是要插入的位置。每次鏈表遍歷一次節(jié)點要將temp的下一節(jié)點賦值給temp節(jié)點避免死循環(huán)。

4、如果flag為真表示,要插入的節(jié)點已經(jīng)存在,輸出插入失??;如果flag為假,令插入節(jié)點的下一節(jié)點指向temp的下一節(jié)點,temp節(jié)點的下一節(jié)點指向帶插入節(jié)點。(畫圖方便理解,圖自行腦補)

public void addOrder(Stu_Node node){
        Stu_Node temp = head;
        boolean flag = false;
        while(true){
            if (temp.next==null)
                break;
            if (temp.next.num >node.num){
                break;
            }
            else if (temp.next.num==node.num){
                flag = true;
                break;
            }
            temp=temp.next;
        }
        if (flag){
            System.out.println("插入失敗");
        }
        else{
            node.next=temp.next;
            temp.next=node;
        }

    }

3>打印鏈表

1、判斷頭結(jié)點的下一個節(jié)點是否為空,如果為空輸出鏈表為空。

2、定義一個temp節(jié)點變量,將頭結(jié)點的指向的節(jié)點賦值給temp。

3、遍歷鏈表打印節(jié)點數(shù)據(jù)。

while循環(huán),打印鏈表節(jié)點,每打印一次temp節(jié)點,使temp節(jié)點的下一節(jié)點賦值給temp避免程序陷入死循環(huán),循環(huán)結(jié)束標(biāo)志是temp的節(jié)點為空(因為temp節(jié)點是頭結(jié)點head的下一節(jié)點)。

class SingleLinkedList{
    Stu_Node head = new Stu_Node(0,"null","null");
    //打印單鏈表
    public void print(){
        if (head.next==null){
            System.out.println("鏈表為空");
        }
        Stu_Node temp = head.next;
        while(true){
            if (temp==null){
                break;
            }
            System.out.println(temp);
            temp=temp.next;
        }
    }
}

4>修改鏈表中的數(shù)據(jù)(假設(shè)學(xué)號為維一值)

1、首先判斷鏈表是否為空

2、定義一個臨時變量temp將頭結(jié)點賦值給temp

3、定義一個Boolean變量flag用于判斷鏈表中是否存在要修改的節(jié)點。

4、遍歷鏈表,while循環(huán)查詢要修改的節(jié)點,每查詢一次就將temp變量賦值為temp的next節(jié)點,如果查詢到要修改的節(jié)點將flag變量賦值為真、終止while循環(huán),如果temp的下一節(jié)點為空表示未找到要修改的節(jié)點變量,此時也終止循環(huán)。

5、判斷flag值為真代表找到當(dāng)前要修改的節(jié)點,將要新的節(jié)點的值賦值給要修改節(jié)點的值;如果flag為假表示未找到當(dāng)前節(jié)點。

class SingleLinkedList{
    Stu_Node head = new Stu_Node(0,"null","null");
    //鏈表的修改方法
    public void update(Stu_Node newnode){
        if (head.next==null){
            System.out.println("鏈表為空");
        }
        Stu_Node temp = head;
        boolean flag = false;
        while (true){
            if (temp.next==null){
                break;
            }
            if (temp.num== newnode.num){
                flag = true;
                break;
            }
            temp=temp.next;
        }
        if (flag){
            temp.name=newnode.name;
            temp.gender= newnode.gender;
        }
        else
            System.out.println("當(dāng)前節(jié)點不存在,無法修改!");
    }
}

5>依據(jù)學(xué)號刪除節(jié)點

1、定義一個臨時節(jié)點temp,將頭結(jié)點賦值給temp

2、定義一個boolean型變量flag用于判斷是否找到當(dāng)前鏈表中待刪除的節(jié)點

3、while循環(huán)遍歷當(dāng)前鏈表,每遍歷一次節(jié)點,將temp節(jié)點的下一節(jié)點賦值給temp避免循環(huán),如果待刪除節(jié)點的學(xué)號跟要刪除的節(jié)點的學(xué)號一至,將flag賦值為true終止while循環(huán),否則持續(xù)遍歷鏈表直到temp節(jié)點的下一節(jié)點為空終止循環(huán)。

4、如果flag為真,代表找到當(dāng)前要刪除的節(jié)點,將temp的下一節(jié)點指向temp下一節(jié)點的下一節(jié)點。,如果flag為假代表找不到待刪除的節(jié)點。

class SingleLinkedList{
    Stu_Node head = new Stu_Node(0,"null","null");
    //刪除鏈表的節(jié)點
    public void delete(int no){
        Stu_Node temp = head;
        boolean flag = false;
        while(true){
            if (temp.next==null)
                break;
            if (temp.next.num==no){
                flag=true;
                break;
            }
            temp = temp.next;
        }
        if (flag){
            temp.next=temp.next.next;
        }
        else{
            System.out.println("未找到要刪除的鏈表");
        }

    }
}

三、新建操作鏈表類的實現(xiàn)類實現(xiàn)其增刪改查功能

1、新建操作鏈表類的實現(xiàn)類對象

2、新建多個待操作的節(jié)點

3、使用新建的鏈表操作類對象進行增刪改查功能

完整代碼如下:

public class linkedlist {
    public static void main(String[] args) {
        SingleLinkedList list = new SingleLinkedList();
        Stu_Node node1 = new Stu_Node(1903210086,"小明","男");
        Stu_Node node2 = new Stu_Node(1903210087,"小花","女");
        Stu_Node node3 = new Stu_Node(1903210088,"小黃","男");
        Stu_Node node4 = new Stu_Node(1903210089,"小翠","女");
        list.add(node1);
        list.add(node4);
        list.add(node3);
        list.add(node2);
        list.print();
        System.out.println("----------------------");
        System.out.println("按學(xué)號順序插入節(jié)點");
        SingleLinkedList list_1= new SingleLinkedList();
        list_1.addOrder(node1);
        list_1.addOrder(node4);
        list_1.addOrder(node3);
        list_1.addOrder(node2);
        list_1.print();
        System.out.println("-----------------------");
        Stu_Node node5 = new Stu_Node(1903210089,"賈明","男");
        list.update(node5);
        list.print();
        System.out.println("#######################");
        System.out.println("刪除之后的鏈表");
        list.delete(1903210088);
        list.print();
    }
}
class Stu_Node{
    int num;
    String name;
    String gender;
    Stu_Node next;

    @Override
    public String toString() {
        return "Stu_Node{" +
                "num=" + num +
                ", name='" + name + '\'' +
                ", gender='" + gender + '\'' +
                '}';
    }
    public Stu_Node(int num, String name, String gender){
        this.num=num;
        this.name=name;
        this.gender=gender;
    }
}

class SingleLinkedList{
    Stu_Node head = new Stu_Node(0,"null","null");
    //鏈表的尾節(jié)點添加方法
    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 addOrder(Stu_Node node){
        Stu_Node temp = head;
        boolean flag = false;
        while(true){
            if (temp.next==null)
                break;
            if (temp.next.num >node.num){
                break;
            }
            else if (temp.next.num==node.num){
                flag = true;
                break;
            }
            temp=temp.next;
        }
        if (flag){
            System.out.println("插入失敗");
        }
        else{
            node.next=temp.next;
            temp.next=node;
        }

    }
    public void print(){
        if (head.next==null){
            System.out.println("鏈表為空");
        }
        Stu_Node temp = head.next;
        while(true){
            if (temp==null){
                break;
            }
            System.out.println(temp);
            temp=temp.next;
        }
    }
    public void update(Stu_Node newnode){
        if (head.next==null){
            System.out.println("鏈表為空");
        }
        Stu_Node temp = head;
        boolean flag = false;
        while (true){
            if (temp.next==null){
                break;
            }
            if (temp.num== newnode.num){
                flag = true;
                break;
            }
            temp=temp.next;
        }
        if (flag){
            temp.name=newnode.name;
            temp.gender= newnode.gender;
        }
        else
            System.out.println("當(dāng)前節(jié)點不存在,無法修改!");
    }
    public void delete(int no){
        Stu_Node temp = head;
        boolean flag = false;
        while(true){
            if (temp.next==null)
                break;
            if (temp.next.num==no){
                flag=true;
                break;
            }
            temp = temp.next;
        }
        if (flag){
            temp.next=temp.next.next;
        }
        else{
            System.out.println("未找到要刪除的鏈表");
        }

    }
}

總結(jié)

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

相關(guān)文章

  • Java 重入鎖和讀寫鎖的具體使用

    Java 重入鎖和讀寫鎖的具體使用

    這篇文章主要介紹了Java 重入鎖和讀寫鎖的具體使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Java靜態(tài)和非靜態(tài)成員變量初始化過程解析

    Java靜態(tài)和非靜態(tài)成員變量初始化過程解析

    這篇文章主要介紹了Java靜態(tài)和非靜態(tài)成員變量初始化過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-01-01
  • Spring中Bean掃描原理詳情

    Spring中Bean掃描原理詳情

    這篇文章主要介紹了Spring中Bean掃描原理詳情,文章為榮啊主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-07-07
  • Java堆空間爆滿導(dǎo)致宕機的問題分析及解決

    Java堆空間爆滿導(dǎo)致宕機的問題分析及解決

    團隊有一個服務(wù),一直運行的好好的,突然訪問異常了,先是請求超時,然后直接無法訪問,本文將給大家介紹Java堆空間爆滿導(dǎo)致宕機的問題分析及解決,需要的朋友可以參考下
    2024-02-02
  • 解讀Java中char類型相加的問題

    解讀Java中char類型相加的問題

    這篇文章主要介紹了解讀Java中char類型相加的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • @CacheEvict注解,清除緩存方式

    @CacheEvict注解,清除緩存方式

    這篇文章主要介紹了@CacheEvict注解,清除緩存方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Java @PostMapping和@GetMapping方法使用詳解

    Java @PostMapping和@GetMapping方法使用詳解

    這篇文章主要介紹了Java @PostMapping和@GetMapping方法使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-03-03
  • 談?wù)剬ava中的volatile的理解

    談?wù)剬ava中的volatile的理解

    這篇文章主要介紹了對Java中的volatile的理解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • Java中toString()、String.valueOf、(String)強轉(zhuǎn)區(qū)別

    Java中toString()、String.valueOf、(String)強轉(zhuǎn)區(qū)別

    相信大家在日常開發(fā)中這三種方法用到的應(yīng)該很多,本文主要介紹了Java中toString()、String.valueOf、(String)強轉(zhuǎn)區(qū)別,感興趣的可以了解一下
    2021-09-09
  • java實現(xiàn)簡單猜拳小游戲

    java實現(xiàn)簡單猜拳小游戲

    這篇文章主要為大家詳細(xì)介紹了java實現(xiàn)簡單猜拳小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11

最新評論