国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|JavaScript|易語言|

服務器之家 - 編程語言 - Java教程 - Java雙向鏈表按照順序添加節點的方法實例

Java雙向鏈表按照順序添加節點的方法實例

2021-08-03 11:18星星照亮你的禿頂 Java教程

這篇文章主要給大家介紹了關于Java雙向鏈表按照順序添加節點的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

分析過程:

首先需要比較待添加的節點編號與已有的節點編號的大小,若待添加的節點編號已經存在,則不能加入。為防止出現空指針的情況,需要對節點的位置進行判斷。

示例代碼:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
package linkedlist;
 
public class DoubleLinkedListDemo {
 
    public static void main(String[] args) {
        // 測試
        System.out.println("雙向鏈表的測試");
        // 創建節點
        Node node1 = new Node(1, "道明寺");
        Node node2 = new Node(2, "花澤類");
        Node node3 = new Node(3, "西門總二郎");
        Node node4 = new Node(4, "美作玲");
        // 創建一個雙向鏈表
        DoubleLinkedList doubleLinkedList = new DoubleLinkedList();
        // 添加節點
        doubleLinkedList.addByOrder(node1);
        doubleLinkedList.addByOrder(node4);
        doubleLinkedList.addByOrder(node3);
        doubleLinkedList.addByOrder(node2);
        // 顯示排序后的雙向鏈表
        doubleLinkedList.list();
    }
}
 
// 創建一個雙向鏈表的類
class DoubleLinkedList {
    // 先初始化頭節點,頭節點不動
    private Node head = new Node(0, "");
    
    // 返回頭節點
    public Node getHead() {
        return head;
    }
    
    // 添加節點時,根據編號將節點插入到指定位置
    // 如果有這個編號,則添加失敗,并給出提示
    public void addByOrder(Node node) {
        // 頭節點不能動,通過一個輔助指針(變量)幫助找到需要添加的位置
        Node temp = head;
        boolean flag = false;   // flag標志添加的編號是否存在,默認為false
        while(true) {
            if(temp.next == null) {
                break;
            }
            if(temp.next.no > node.no) {
                break;
            }
            if(temp.next.no == node.no) {
                flag = true;
                break;
            }
            temp = temp.next;   // 遍歷鏈表
        }
        if(flag) {
            System.out.printf("輸入的編號%d已經存在,不能加入\n", node.no);
        }
        else {
            // 為防止出現空指針的情況,需要對temp節點位置進行判斷
            // 若雙向鏈表尚未到達尾端,則需要將node節點與其相鄰的后面的節點進行連接
            if(temp.next != null) {
                node.next = temp.next;
                temp.next.pre = node;
            }
            // 無論雙向鏈表是否到達尾端,都需要將node節點與其相鄰的前面的節點進行連接
            temp.next = node;
            node.pre = temp;
        }
    }
    
    // 遍歷雙向鏈表的方法
    // 顯示鏈表【遍歷】
    public void list() {
        // 判斷鏈表是否為空
        if(head.next == null) {
            System.out.println("鏈表為空");
            return;
        }
        // 因為頭節點不能動,需要一個輔助變量來遍歷
        Node temp = head.next;
        while (true) {
            // 判斷是否到鏈表最后
            if(temp == null)
                break;
            // 輸出節點的信息
            System.out.println(temp);
            // 將temp后移
            temp = temp.next;
        }
    }
}
 
// 創建一個雙向鏈表的類
// 定義Node,每個Node對象就是一個節點
class Node {
    public int no;
    public String name;
    public Node next;   // 指向下一個節點,默認為null
    public Node pre;    // 指向前一個節點,默認為null
    // 構造器
    public Node(int no, String name) {
        this.no = no;
        this.name = name;
    }
    // 為了顯示方便,重新toString
    @Override
    public String toString() {
        return "Node [no=" + no + ", name=" + name +"]";
    }
}

運行結果運行結果

Java雙向鏈表按照順序添加節點的方法實例

總結

到此這篇關于Java雙向鏈表按照順序添加節點的文章就介紹到這了,更多相關Java雙向鏈表按照順序添加節點內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/Peppaaa/article/details/113546576

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 一区二区三区四区免费看 | 依人成人综合网 | 粉色在线观看 | 国产一区二区三区在线免费观看 | 成人精品一区二区三区中文字幕 | 伊人五月婷婷 | 岛国搬运工av在线播放 | 亚洲精品久久久久久久久久吃药 | 91在线中文| 国产黄色免费看 | 综合色爱 | 黄色免费看片网站 | 精品国产一区二区三区四 | 亚洲成av人片一区二区梦乃 | 黄在线观看| 欧美一区二区三区在线视频 | 黄色av免费 | 国产一区二区三区免费看 | 伊人网在线视频观看 | 国产精品伦一区二区三级视频 | 亚洲91精品 | 日日摸夜夜添夜夜添精品视频 | 亚洲视频免费在线观看 | 天天干狠狠干 | 欧美xo影院| 2018自拍偷拍 | 日韩精品久久久 | 日韩精品中文字幕在线 | 久久精品国产精品青草 | 欧美日韩国产在线 | 久热中文在线 | 日韩五码 | 精品国产乱码久久久久久影片 | 91欧美激情一区二区三区成人 | 一级中文字幕 | 欧美成人a | 色综合天天网 | 精品欧美 | 91 在线免费观看 | 日韩欧美成人影院 | 亚洲社区在线 |