"LinkedList" (データ構造)
"LinkedList"
要素が一般式である連結リストを表す.
詳細
- 連結リストは,効率的に要素をプリペンドしたり,加えたりするのに役立つ.
-
CreateDataStructure["LinkedList"] 新しい空の"LinkedList"を作成する CreateDataStructure["LinkedList",elems] elems を含む新しい空の"LinkedList"を作成する Typed[x,"LinkedList"] x に"LinkedList"型を与える - "LinkedList"型のデータ構造には,以下の演算が使える.
-
ds["Append",x] x を ds に加える time: O(1) ds["Copy"] ds のコピーを返す time: O(n) ds["DropAll"] ds からすべての要素を省く time: O(n) ds["DropFirst"] ds の最初の要素を省く time: O(1) ds["Elements"] ds の要素のリストを返す time: O(n) ds["EmptyQ"] ds が要素を持たない場合はTrue time: O(1) ds["Fold",fun,init] fun を ds の要素に適用する.init で始めて,結果を累積する time: O(n) ds["JoinBack",elems] elems を ds の後ろに繋ぐ time: O(nelems) ds["JoinFront",elems] elems を ds の前に繋ぐ time: O(nelems) ds["Length"] ds に保存された要素の数 time: O(1) ds["Part",i] ds の i 番目の部分を返す time: O(n) ds["Prepend",x] x を ds の先頭に追加する time: O(1) ds["SetPart",i,elem] ds の i 番目の部分を更新する time: O(n) ds["SwapPart",i,j] ds の i 番目と j 番目の部分を交換する time: O(n) ds["Visualization"] ds の可視化を返す time: O(n) - 以下の関数もサポートする.
-
dsi===dsj dsi が dsj に等しい場合はTrue ds["Part",i]=val ds の i 番目の要素を val に設定する FullForm[ds] ds の完全形 Information[ds] ds についての情報 InputForm[ds] ds の入力形 Normal[ds] ds を通常の式に変換する
例題
すべて開くすべて閉じる例 (2)
新しい"LinkedList"は,CreateDataStructureを使って作成できる:
スコープ (1)
情報 (1)
新しい"LinkedList"は,CreateDataStructureを使って作成することができる: