|
簡潔データ構造 (かんけつデータこうぞう、) とは計算機科学の用語で、情報理論的下界に「近い」領域量だけを使いつつ、(他の圧縮形式とは異なり)効率的に質問を受け付けることができるデータ構造を指す。その概念は最初 Jacobson 〔 によって、木、平面的グラフを符号化するために導入された。通常のロスなしデータ圧縮アルゴリズムとは異なり、簡潔データ構造は事前の展開操作をせずに使用することができる。は関連する考え方に基づいているが、圧縮データ構造ではデータ構造のサイズは表現しようとする特定のデータに依存する。 あるデータを保持するために必要な情報理論的に最小のビット数がだとする。このデータの表現形式は、 * ビットの領域を必要とする場合、'、 * ビットの領域を必要とする場合、''簡潔'' (''succinct'')、 * ビットの領域を必要とする場合、''コンパクト'' (''compact'') であると呼ばれる。 implicit データ構造は通常、なんらかの順列を用いて情報を保持することに帰着される。よく知られる事例としてはヒープが挙げられる。、 * ビットの領域を必要とする場合、''簡潔'' (''succinct'')、 * ビットの領域を必要とする場合、''コンパクト'' (''compact'') であると呼ばれる。 implicit データ構造は通常、なんらかの順列を用いて情報を保持することに帰着される。よく知られる事例としてはヒープが挙げられる。 ==簡潔辞書== 簡潔索引つき辞書(簡潔ビットベクトル、完備辞書とも呼ぶ)は、''rank/select'' 辞書とも呼ばれ、二分木、分木、多重集合〔や、接尾辞木、接尾辞配列などの多数の簡潔表現手法の基礎をなしている〔。基本的な問題設定は、 実用上は、ルックアップ表 をビット命令とより小さい表で置き換え、小ブロックで立っているビットの数を調べるようにすることができる。多くの場合、こうすることで大きなデータセットで簡潔データ構造を用いる際の、キャッシュミスの増大とそれによって起こるルックアップ表がキャッシュから追い出されるという問題に対処できる〔。select質問は、''rank''に用いたものと同じ補助データ構造と二分探索とを合わせることで容易にサポートできるが、そのやり方では最悪の場合 の時間がかかる。 ビットの追加領域を用いる、より複雑なデータ構造により、selectは定数時間でサポートできる〔。こうした解決法の多くでは、実用上、漸近的な特長が効果を発揮する至らない場合、記法に隠れた定数が支配的となる。その場合、長ワード命令とワードサイズに揃えたブロックを利用した実装のほうが効率的であることが多い〔。 抄文引用元・出典: フリー百科事典『 ウィキペディア(Wikipedia)』 ■ウィキペディアで「簡潔データ構造」の詳細全文を読む スポンサード リンク
|