検索
ホームページバックエンド開発C++指定された文字列リストから構築されたトライの可能なノードをすべて出力します。

C では、trie はツリーのコレクションを格納するために使用される高レベルのデータ構造です。トライという言葉は検索という言葉に由来しており、番号ツリーまたは接頭辞ツリーと呼ばれます。

文字列のリストが与えられた場合に考えられるすべての結合の例を見てみましょう。

入力文字列を {"tutor", "true", "tuo"}

指定された文字列リストから構築されたトライの可能なノードをすべて出力します。

として定義します。

異なる文字列が 1 つの文字列に連結されていることがわかります。したがって、ここの tu は、すべての可能な文字列を接続する文字リストです。

この記事では、trie データ構造を使用して、文字列のリスト内のすべての可能な接続を解決します。

###文法### リーリー

パラメータ

  • struct

    -このキーワードは、構造データ型を表すために使用されます。

  • name_of_ Structure

    - 構造に任意の名前を指定します。

  • 構造とは、関連するさまざまな変数を 1 か所に集めたものです。
  • リーリー
  • alpha は、treetrie という名前の
構造体ポインター/データ メンバー

を指す変数の名前です。 alphabet は、文字の合計値を整数として設定するマクロです。 ###アルゴリズム###

最初に、

‘bits/stdc .h’
    という名前のヘッダー ファイルを使用します。これには、C の標準テンプレート ライブラリがすべて含まれています。
  • 2 つのマクロ

    'alphabet'
  • 'max'

    を定義しています。これらは、アルファベットの合計文字数と文字の最大値を定義します。

    'tree node'
  • という構造体を作成し、レターのアドレスを格納するための
  • 'tree_node'

    へのポインタを定義しています。 bool データ型を使用して変数 'end_word' を定義します。これは文字列の終了文字として使用されます。 ポインタを使用して、トライによって構築されたツリーを表す新しいノードに接続し、

    'buildNode'
  • という関数を定義します。
  • 文字列を挿入するには、

    'ins_recursive_of_string'
  • という再帰関数を作成します。この関数は、itm、str (挿入される文字列)、i (挿入される現在の文字を表す 3 つのパラメータ) を受け入れます。加工済み)。
  • 関数

    ins()
  • は、
  • ins_recursive_of_str()

    のラッパー関数としてコード内で定義されています。 tree_trie* itm (tree_trie オブジェクト) と string str (挿入される文字列) の 2 つのパラメーターを受け入れます。現在のノード、挿入される文字列、開始インデックス 0 を使用して再帰関数を呼び出します。 次に、

    LeafNode()
  • という関数を作成します。この関数は、tree_trie オブジェクトをパラメータとして受け取り、それがリーフ ノードであるかどうか、つまり子ノードがないかどうかを確認します。
  • Function

    display_joint()
  • はコードで定義されており、4 つのパラメータを受け入れます:
  • tree_trie* root、tree_trie* itm

    (現在処理中のノード)、 char str[] (ルート ノードから現在のノードまで形成されたパス文字列を格納するために使用される文字配列 str)、および int レベル (現在のノードの深さを表す整数レベル)。 このコードは、

    display_joint()
  • のラッパー関数である
  • displayJ()

    関数を定義します。これは、tree_trie オブジェクトをパラメータとして受け取り、ルート ノード、空の文字配列、および開始レベル 0 をパラメータとして使用して display_joint() 関数を呼び出します。 このコードは、新しい

    tree_trie
  • オブジェクトを Trie ルート ノードとして生成する main() 関数を定義します。トライに挿入される文字列のリストを含むベクトル s を生成します。次に、
  • ins()

    関数を呼び出して、各文字列をトライに挿入します。 最後に、出力の開始を示すメッセージを出力し、

    displayJ()
  • 関数を呼び出してすべての Trie 接続ポイントを表示します。
  • ###例### このプログラムでは、指定された文字列リストから構築されたトライの可能な結合点をすべて出力します。

    リーリー ###出力### リーリー ###結論は###
  • 私たちはトライ データ構造の概念を検討し、指定された文字列リストから可能なすべてのトライ結合ポイントを構築しました。出力では、文字 u と t が、tutor、true、tuo などの文字列を使用してトライのすべての可能な結合ポイントを接続していることがわかります。したがって、ツリーは可能な接続点を与えることによってノードを減らすことができます。

以上が指定された文字列リストから構築されたトライの可能なノードをすべて出力します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事はtutorialspointで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
cインタビューの質問と回答:次の技術評価をエースcインタビューの質問と回答:次の技術評価をエースApr 28, 2025 am 12:10 AM

cインタビューでは、スマートポインターは、メモリを管理し、メモリリークを減らすのに役立つ重要なツールです。 1)std :: siquire_ptrは、リソースが自動的にリリースされることを確認するための独占的な所有権を提供します。 2)std :: shared_ptrは共有所有権に使用され、マルチリファレンスシナリオに適しています。 3)std :: weak_ptrは、循環参照を回避し、安全なリソース管理を確保することができます。

Cの未来:適応と革新Cの未来:適応と革新Apr 27, 2025 am 12:25 AM

Cの将来は、並列コンピューティング、セキュリティ、モジュール化、AI/機械学習に焦点を当てます。1)並列コンピューティングは、コルーチンなどの機能を介して強化されます。 2)セキュリティは、より厳格なタイプのチェックとメモリ管理メカニズムを通じて改善されます。 3)変調は、コード組織とコンパイルを簡素化します。 4)AIと機械学習は、数値コンピューティングやGPUプログラミングサポートなど、CにComply Coveに適応するように促します。

Cの寿命:現在の状態を調べますCの寿命:現在の状態を調べますApr 26, 2025 am 12:02 AM

Cは、効率的で柔軟で強力な性質のため、最新のプログラミングで依然として重要です。 1)Cシステムプログラミング、ゲーム開発、組み込みシステムに適したオブジェクト指向プログラミングをサポートします。 2)多型はCのハイライトであり、基本クラスのポインターまたはコードの柔軟性とスケーラビリティを強化するための参照を介して派生クラスのメソッドを呼び出すことができます。

C#対Cパフォーマンス:ベンチマークと考慮事項C#対Cパフォーマンス:ベンチマークと考慮事項Apr 25, 2025 am 12:25 AM

C#とCのパフォーマンスの違いは、主に実行速度とリソース管理に反映されます。1)Cは通常、ハードウェアに近く、ガベージコレクションなどの追加のオーバーヘッドがないため、数値計算と文字列操作でより良いパフォーマンスを発揮します。 2)C#はマルチスレッドプログラミングでより簡潔ですが、そのパフォーマンスはCよりもわずかに劣っています。 3)プロジェクトの要件とチームテクノロジースタックに基づいて、どの言語を選択するかを決定する必要があります。

C:それは死にかけていますか、それとも単に進化していますか?C:それは死にかけていますか、それとも単に進化していますか?Apr 24, 2025 am 12:13 AM

c isnotdying; it'sevolving.1)c relelevantdueToitsversitileSileSixivisityinperformance-criticalApplications.2)thelanguageSlikeModulesandCoroutoUtoimveUsablive.3)despiteChallen

C現代の世界:アプリケーションと産業C現代の世界:アプリケーションと産業Apr 23, 2025 am 12:10 AM

Cは、現代世界で広く使用され、重要です。 1)ゲーム開発において、Cは、非現実的や統一など、その高性能と多型に広く使用されています。 2)金融取引システムでは、Cの低レイテンシと高スループットが最初の選択となり、高周波取引とリアルタイムのデータ分析に適しています。

C XMLライブラリ:オプションの比較と対照C XMLライブラリ:オプションの比較と対照Apr 22, 2025 am 12:05 AM

C:tinyxml-2、pugixml、xerces-c、およびrapidxmlには、一般的に使用される4つのXMLライブラリがあります。 1.TinyXML-2は、リソースが限られている環境、軽量ではあるが機能が限られていることに適しています。 2。PUGIXMLは高速で、複雑なXML構造に適したXPathクエリをサポートしています。 3.Xerces-Cは強力で、DOMとSAXの解像度をサポートし、複雑な処理に適しています。 4。RapidXMLはパフォーマンスと分割に非常に高速に焦点を当てていますが、XPathクエリをサポートしていません。

CおよびXML:関係とサポートの調査CおよびXML:関係とサポートの調査Apr 21, 2025 am 12:02 AM

Cは、サードパーティライブラリ(TinyXML、PUGIXML、XERCES-Cなど)を介してXMLと相互作用します。 1)ライブラリを使用してXMLファイルを解析し、それらをC処理可能なデータ構造に変換します。 2)XMLを生成するときは、Cデータ構造をXML形式に変換します。 3)実際のアプリケーションでは、XMLが構成ファイルとデータ交換に使用されることがよくあり、開発効率を向上させます。

See all articles

ホット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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 Mac版

SublimeText3 Mac版

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

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター