中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

Go語言怎么刪除鏈表元素

小億
87
2024-01-27 14:22:58
欄目: 編程語言

在Go語言中,我們可以使用指針來刪除鏈表中的元素。首先,我們需要定義一個鏈表節點的結構體,其中包含一個值和一個指向下一個節點的指針。然后,我們可以使用指針遍歷鏈表,找到需要刪除的節點,并將其前一個節點的指針指向需要刪除節點的下一個節點,從而刪除該節點。

下面是一個示例代碼,演示了如何刪除鏈表中的元素:

package main

import "fmt"

// 鏈表節點結構體
type ListNode struct {
    Val  int
    Next *ListNode
}

// 遍歷鏈表打印所有節點的值
func printList(head *ListNode) {
    cur := head
    for cur != nil {
        fmt.Printf("%d ", cur.Val)
        cur = cur.Next
    }
    fmt.Println()
}

// 刪除鏈表中的指定元素
func deleteNode(head *ListNode, val int) *ListNode {
    // 頭節點特殊處理
    if head.Val == val {
        return head.Next
    }

    cur := head
    for cur.Next != nil {
        // 找到需要刪除的節點
        if cur.Next.Val == val {
            cur.Next = cur.Next.Next
            return head
        }
        cur = cur.Next
    }

    return head
}

func main() {
    // 創建鏈表 1 -> 2 -> 3 -> 4 -> 5
    head := &ListNode{Val: 1}
    node2 := &ListNode{Val: 2}
    node3 := &ListNode{Val: 3}
    node4 := &ListNode{Val: 4}
    node5 := &ListNode{Val: 5}
    head.Next = node2
    node2.Next = node3
    node3.Next = node4
    node4.Next = node5

    // 刪除鏈表中的元素 3
    head = deleteNode(head, 3)

    // 打印刪除元素后的鏈表
    printList(head)
}

運行上述代碼,輸出結果為:1 2 4 5,表示成功刪除了鏈表中的元素 3。

0
龙里县| 正定县| 于田县| 呼和浩特市| 洪洞县| 濉溪县| 响水县| 青浦区| 平山县| 合川市| 宁南县| 铜陵市| 商洛市| 封丘县| 定结县| 尉氏县| 从化市| 石柱| 盘山县| 西平县| 马尔康县| 嘉义市| 石林| 长武县| 神木县| 浪卡子县| 乌兰浩特市| 浦北县| 红安县| 黎川县| 承德市| 玉龙| 从江县| 琼海市| 天台县| 临城县| 吴堡县| 章丘市| 青龙| 沁阳市| 汽车|