目次
単連結リストの定義
単一リンク リストのノード定義
単一リンク リストの初期化
単連結リストの挿入操作
単一リンク リストの削除操作
単一リンク リストのトラバーサル操作
サンプル コード
ホームページ バックエンド開発 Golang Go 言語プログラミング ガイド: 単一リンク リストの実装の詳細な説明

Go 言語プログラミング ガイド: 単一リンク リストの実装の詳細な説明

Mar 22, 2024 pm 05:18 PM
言語を移動 成し遂げる 単一リスト

Go 言語プログラミング ガイド: 単一リンク リストの実装の詳細な説明

Go 言語プログラミング ガイド: 単一リンク リストの実装の詳細な説明

Go 言語では、単一リンク リストは一連の要素を格納するために使用される一般的なデータ構造であり、シーケンシャルアクセス。この記事では、単一リンクリストの実装原理を詳しく紹介し、具体的な Go 言語のコード例を示します。

単連結リストの定義

単連結リストは、各要素 (ノード) にデータ フィールドとポインター フィールドの 2 つの部分が含まれる線形リスト データ構造です。データ フィールドは要素の値を格納するために使用され、ポインター フィールドは次のノードを指します。最後のノードのポインタ フィールドは通常は空で、リンク リストの終わりを示します。

単一リンク リストのノード定義

まず、単一リンク リストのノード タイプを定義します。

type Node struct {
    data int
    next *Node
}
ログイン後にコピー

その中で、dataフィールドにはノードの値が格納されます。nextフィールドには、次のノードへのポインタが格納されます。

単一リンク リストの初期化

次に、単一リンク リストの初期化関数を定義します。

type LinkedList struct {
    head *Node
}

func NewLinkedList() *LinkedList {
    return &LinkedList{}
}
ログイン後にコピー

初期化関数では、空のリンク リストを作成し、 head ノード ポインタは null に初期化されます。

単連結リストの挿入操作

単連結リストの挿入操作は、連結リストの先頭にノードを挿入する場合と、末尾にノードを挿入する場合の 2 つの状況に分けられます。リンクされたリスト。

最初の関数は、リンク リストの先頭にノードを挿入する関数です。

func (list *LinkedList) InsertAtBeginning(value int) {
    newNode := &Node{data: value}
    newNode.next = list.head
    list.head = newNode
}
ログイン後にコピー

この関数では、まず新しいノードを作成し、その値を渡された値に初期化します。次に、新しいノードのポインタをリンク リストの先頭にポイントし、最後にリンク リストの先頭ノードを新しいノードに更新します。

次は、リンク リストの最後にノードを挿入する関数です。

func (list *LinkedList) InsertAtEnd(value int) {
    newNode := &Node{data: value}
    if list.head == nil {
        list.head = newNode
        return
    }

    current := list.head
    for current.next != nil {
        current = current.next
    }
    current.next = newNode
}
ログイン後にコピー

この関数は、まず新しいノードを作成し、リンク リストが空かどうかを判断します。空の場合は、新しいノードが直接ヘッド ノードとして設定されます。それ以外の場合は、最後のノードが見つかるまでリンク リストが走査され、その後、新しいノードが最後のノードの後に​​挿入されます。

単一リンク リストの削除操作

削除操作は、ヘッド ノードの削除と指定された値を持つノードの削除の 2 つの状況に分かれます。

最初の関数は、ヘッド ノードを削除する関数です。

func (list *LinkedList) DeleteAtBeginning() {
    if list.head == nil {
        return
    }
    list.head = list.head.next
}
ログイン後にコピー

この関数は、ヘッド ノード ポインターを次のノードに直接ポイントすることで、ヘッド ノードを削除します。

次は、指定された値を持つノードを削除する関数です:

func (list *LinkedList) DeleteByValue(value int) {
    if list.head == nil {
        return
    }
    if list.head.data == value {
        list.head = list.head.next
        return
    }

    prev := list.head
    current := list.head.next
    for current != nil {
        if current.data == value {
            prev.next = current.next
            return
        }
        prev = current
        current = current.next
    }
}
ログイン後にコピー

この関数では、まずリンク リストが空かどうかを判断する必要があります。次に、ヘッド ノードから開始してリンク リストを走査し、ターゲット値が存在するノードを見つけて削除します。

単一リンク リストのトラバーサル操作

最後は、単一リンク リストのトラバーサル操作です:

func (list *LinkedList) Print() {
    current := list.head
    for current != nil {
        fmt.Print(current.data, " ")
        current = current.next
    }
    fmt.Println()
}
ログイン後にコピー

この関数は、ヘッド ノードから開始してノードの値を 1 つずつ出力します。リンクされたリストの最後まで。

サンプル コード

以下は、単一リンク リストの使用方法を示す完全なサンプル コードです。

package main

import "fmt"

type Node struct {
    data int
    next *Node
}

type LinkedList struct {
    head *Node
}

func NewLinkedList() *LinkedList {
    return &LinkedList{}
}

func (list *LinkedList) InsertAtBeginning(value int) {
    newNode := &Node{data: value}
    newNode.next = list.head
    list.head = newNode
}

func (list *LinkedList) InsertAtEnd(value int) {
    newNode := &Node{data: value}
    if list.head == nil {
        list.head = newNode
        return
    }

    current := list.head
    for current.next != nil {
        current = current.next
    }
    current.next = newNode
}

func (list *LinkedList) DeleteAtBeginning() {
    if list.head == nil {
        return
    }
    list.head = list.head.next
}

func (list *LinkedList) DeleteByValue(value int) {
    if list.head == nil {
        return
    }
    if list.head.data == value {
        list.head = list.head.next
        return
    }

    prev := list.head
    current := list.head.next
    for current != nil {
        if current.data == value {
            prev.next = current.next
            return
        }
        prev = current
        current = current.next
    }
}

func (list *LinkedList) Print() {
    current := list.head
    for current != nil {
        fmt.Print(current.data, " ")
        current = current.next
    }
    fmt.Println()
}

func main() {
    list := NewLinkedList()

    list.InsertAtEnd(1)
    list.InsertAtEnd(2)
    list.InsertAtEnd(3)
    list.Print()

    list.DeleteByValue(2)
    list.Print()

    list.DeleteAtBeginning()
    list.Print()
}
ログイン後にコピー

上記は、Go 言語を使用して次のことを行うための詳細なガイドです。単一リンクリストを実装します。この記事の紹介とサンプル コードを通じて、読者が単一リンク リストの原理と実装についてより深く理解できることを願っています。

以上がGo 言語プログラミング ガイド: 単一リンク リストの実装の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Redisストリームを使用してGO言語でメッセージキューを実装する場合、user_idタイプの変換の問題を解決する方法は? Redisストリームを使用してGO言語でメッセージキューを実装する場合、user_idタイプの変換の問題を解決する方法は? Apr 02, 2025 pm 04:54 PM

redisstreamを使用してGo言語でメッセージキューを実装する問題は、GO言語とRedisを使用することです...

Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか? Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか? Apr 02, 2025 pm 05:09 PM

Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか?ゴーランドを使用するためにGolandを使用する場合、多くの開発者はカスタム構造タグに遭遇します...

Go's Crawler Collyのキュースレッドの問題は何ですか? Go's Crawler Collyのキュースレッドの問題は何ですか? Apr 02, 2025 pm 02:09 PM

Go Crawler Collyのキュースレッドの問題は、Go言語でColly Crawler Libraryを使用する問題を調査します。 �...

Goでは、Printlnとstring()関数を備えた文字列を印刷すると、なぜ異なる効果があるのですか? Goでは、Printlnとstring()関数を備えた文字列を印刷すると、なぜ異なる効果があるのですか? Apr 02, 2025 pm 02:03 PM

Go言語での文字列印刷の違い:printlnとstring()関数を使用する効果の違いはGOにあります...

GOの浮動小数点番号操作に使用されるライブラリは何ですか? GOの浮動小数点番号操作に使用されるライブラリは何ですか? Apr 02, 2025 pm 02:06 PM

GO言語の浮動小数点数操作に使用されるライブラリは、精度を確保する方法を紹介します...

GO言語の「VAR」と「タイプ」キーワード定義構造の違いは何ですか? GO言語の「VAR」と「タイプ」キーワード定義構造の違いは何ですか? Apr 02, 2025 pm 12:57 PM

GO言語で構造を定義する2つの方法:VARとタイプのキーワードの違い。構造を定義するとき、GO言語はしばしば2つの異なる執筆方法を見ます:最初...

GOのどのライブラリが大企業によって開発されていますか、それとも有名なオープンソースプロジェクトによって提供されていますか? GOのどのライブラリが大企業によって開発されていますか、それとも有名なオープンソースプロジェクトによって提供されていますか? Apr 02, 2025 pm 04:12 PM

大企業または有名なオープンソースプロジェクトによって開発されたGOのどのライブラリが開発されていますか? GOでプログラミングするとき、開発者はしばしばいくつかの一般的なニーズに遭遇します...

SQL.Openを使用するとき、DSNが空に渡されたときにエラーを報告しないのはなぜですか? SQL.Openを使用するとき、DSNが空に渡されたときにエラーを報告しないのはなぜですか? Apr 02, 2025 pm 12:54 PM

SQL.Openを使用する場合、DSNがエラーを報告しないのはなぜですか? GO言語では、sql.open ...

See all articles