リンク リストは一連のノードで構成される一般的なデータ構造で、各ノードにはデータと次のノードへのポインターが含まれます。この記事では、Go 言語を使用して簡単なリンク リストを実装します。
1. ノード タイプの定義
最初に、ノード タイプを定義する必要があります。ノードにはデータ要素と次のノードへのポインタが含まれている必要があります。コードは次のとおりです。
type Node struct { Data interface{} //节点存储的数据 Next *Node //指向下一个节点的指针 }
インターフェース{}を使用してノード データを保存します。これにより、リンク リストにあらゆる種類のデータを保存できるようになります。
2. リンク リスト タイプを定義する
次に、リンク リスト タイプを定義する必要があります。これには、最初のノードへのポインタが含まれている必要があります。同時に、AddNode と Traverse という 2 つのメソッドも追加しました。
type LinkedList struct { Head *Node //指向第一个节点的指针 } //添加一个节点 func (l *LinkedList) AddNode(data interface{}) { newNode := &Node{Data: data} if l.Head == nil { l.Head = newNode } else { current := l.Head for current.Next != nil { current = current.Next } current.Next = newNode } } //遍历链表并执行函数 func (l *LinkedList) Traverse(fn func(interface{})) { current := l.Head for current != nil { fn(current.Data) current = current.Next } }
AddNode メソッドは、リンク リストの末尾にノードを追加します。リンクされたリストが空の場合、追加されたノードが最初のノードになります。それ以外の場合は、リンクされたリストを走査し、最後のノードを見つけて、新しいノードを次のノードとして追加します。
Traverse メソッドは、コールバック関数を使用して、リンク リスト内の各ノードを操作します。リンクされたリスト内の各ノードを反復処理し、渡された関数を各ノードで実行します。このメソッドを使用すると、リンク リストを走査して各ノードを出力できます:
func main() { list := LinkedList{} list.AddNode("A") list.AddNode("B") list.AddNode("C") list.Traverse(func(data interface{}) { fmt.Println(data) }) }
上記のコードは出力します:
A B C
3. ノードの削除
次に、リンクリスト内のノードを削除するメソッド。
//删除链表中的节点 func (l *LinkedList) RemoveNode(target interface{}) { if l.Head == nil { return } if l.Head.Data == target { l.Head = l.Head.Next return } current := l.Head for current.Next != nil { if current.Next.Data == target { current.Next = current.Next.Next return } current = current.Next } }
RemoveNode メソッドは、削除するノードを識別するパラメータを受け取り、リンク リストを走査してノードを見つけます。ノードが見つかった場合は、現在のノードの次のポインタを変更してリンク リストから削除します。リンクされたリストが空であるか、ノードが見つからない場合、アクションは実行されません。
完全なコード:
package main import "fmt" type Node struct { Data interface{} //节点存储的数据 Next *Node //指向下一个节点的指针 } type LinkedList struct { Head *Node //指向第一个节点的指针 } //添加一个节点 func (l *LinkedList) AddNode(data interface{}) { newNode := &Node{Data: data} if l.Head == nil { l.Head = newNode } else { current := l.Head for current.Next != nil { current = current.Next } current.Next = newNode } } //遍历链表并执行函数 func (l *LinkedList) Traverse(fn func(interface{})) { current := l.Head for current != nil { fn(current.Data) current = current.Next } } //删除链表中的节点 func (l *LinkedList) RemoveNode(target interface{}) { if l.Head == nil { return } if l.Head.Data == target { l.Head = l.Head.Next return } current := l.Head for current.Next != nil { if current.Next.Data == target { current.Next = current.Next.Next return } current = current.Next } } func main() { list := LinkedList{} list.AddNode("A") list.AddNode("B") list.AddNode("C") //遍历链表 list.Traverse(func(data interface{}) { fmt.Println(data) }) //删除节点并再次遍历链表 list.RemoveNode("B") list.Traverse(func(data interface{}) { fmt.Println(data) }) }
上記のコードは次のように表示されます:
A B C A C
4. まとめ
この記事では、Go 言語を使用してシンプルなコードを実装します。リンクされたリスト。リンク リストは、多くのアルゴリズムやソフトウェア開発シナリオで広く使用されている重要なデータ構造です。実際のコードを記述する場合は、機能の追加やパフォーマンスの評価を検討してください。
以上がgolangでリンクリストを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

OpenSSLは、安全な通信で広く使用されているオープンソースライブラリとして、暗号化アルゴリズム、キー、証明書管理機能を提供します。ただし、その歴史的バージョンにはいくつかの既知のセキュリティの脆弱性があり、その一部は非常に有害です。この記事では、Debian SystemsのOpenSSLの共通の脆弱性と対応測定に焦点を当てます。 Debianopensslの既知の脆弱性:OpenSSLは、次のようないくつかの深刻な脆弱性を経験しています。攻撃者は、この脆弱性を、暗号化キーなどを含む、サーバー上の不正な読み取りの敏感な情報に使用できます。

この記事では、プロファイリングの有効化、データの収集、CPUやメモリの問題などの一般的なボトルネックの識別など、GOパフォーマンスを分析するためにPPROFツールを使用する方法について説明します。

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

この記事では、ユニットテストのためにGOのモックとスタブを作成することを示しています。 インターフェイスの使用を強調し、模擬実装の例を提供し、模擬フォーカスを維持し、アサーションライブラリを使用するなどのベストプラクティスについて説明します。 articl

この記事では、GENICSのGOのカスタムタイプの制約について説明します。 インターフェイスがジェネリック関数の最小タイプ要件をどのように定義するかを詳しく説明し、タイプの安全性とコードの再利用性を改善します。 この記事では、制限とベストプラクティスについても説明しています

この記事では、GOでテーブル駆動型のテストを使用して説明します。これは、テストのテーブルを使用して複数の入力と結果を持つ関数をテストする方法です。読みやすさの向上、重複の減少、スケーラビリティ、一貫性、および

この記事では、コードのランタイム操作に使用されるGoの反射パッケージについて説明します。シリアル化、一般的なプログラミングなどに有益です。実行やメモリの使用量の増加、賢明な使用と最高のアドバイスなどのパフォーマンスコストについて警告します

この記事では、トレースツールを使用してGOアプリケーションの実行フローを分析します。 手動および自動計装技術について説明し、Jaeger、Zipkin、Opentelemetryなどのツールを比較し、効果的なデータの視覚化を強調しています


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

SublimeText3 英語版
推奨: Win バージョン、コードプロンプトをサポート!

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

WebStorm Mac版
便利なJavaScript開発ツール

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

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

ホットトピック



