セット (抽象データ型)
出典: フリー百科事典『ウィキペディア(Wikipedia)』 (2020/04/12 16:23 UTC 版)
ナビゲーションに移動 検索に移動セット(英: set)あるいは集合とは、コンピュータプログラミングで用いられる抽象データ型の一種。順序のないデータの集まりを表現する抽象データ型であり、同一のデータは一つしか含まれないことが保証される。
重複したデータの挿入
データの同一性は与えられた比較関数で判定されるので、外の文脈で同一かどうかは関数依存である。例えば文字列"hoge"
と"HOGE"
は異なるデータと見ることもできるし、大文字・小文字を区別せずに比較すれば(常に大文字化あるいは小文字化したもの同士を比較すれば)同一のデータと見ることもできるといった具合である。
そのような重複するデータを挿入しようとした場合はこれを処理する必要がある。
- 無視する
- 新しい物で置き換える
- 多重化する(→マルチセット参照)
狭義のセットにおいては重複データは無視されるか新しいデータで置き換えるかされる。もしここで多重化することを選択した場合は複数回の削除を行わなければ値は完全に取り除かれない。
アクセス速度は実装により様々だが、二分木(TreeSet)やハッシュテーブル(HashSet)などのデータ構造を用いて高速化を図ることが多い。
その他の抽象データ型との違い
- リストはそれぞれのデータに順序が定義される点が異なる。
- 配列は順序が定義されるほか、静的配列ではさらに格納可能な要素数が変更できない。
- マルチセットは同じデータを複数格納できるが、狭義のセットでは重複したデータは無視される。マルチセットはbagとも呼ばれる。
各プログラミング言語におけるセット
- C++ - 標準テンプレートライブラリに
std::set
および要素の重複を許容するstd::multiset
が定義されている。C++11では、これらに加えてstd::unordered_set
およびstd::unordered_multiset
が追加された。 - Java - インタフェース
java.util.Set
を実装するjava.util.TreeSet
やjava.util.HashSet
など - .NET Framework - System.Collections.Generic.ISet (.NET 4以降) を実装するSystem.Collections.Generic.SortedSet (.NET 4以降) やSystem.Collections.Generic.HashSet (.NET 3.5 SP1以降) など
- Python - ミュータブルな
set
型と、イミュータブルなfrozenset
型がある。[1] - Ruby - 標準添付の
set
ライブラリにSet
クラスと、ソートされた順番で取り出されるSortedSet
クラスがある。[2]
参照
関連項目
|
|
「セット (抽象データ型)」の例文・使い方・用例・文例
- 目覚まし時計を6時にセットする
- サンセット大通り
- スカーレットはコルセットを脱いだ
- ピンセット1本
- 彼はそのセットの第二ゲームと第三ゲームをとった
- 模型飛行機セット
- 彼女はわきをひもで締めるコルセットを着けていた
- 試合の第1セットを落とした時点であまり望みがなくなった
- そのテニスの試合はセットカウント3対2という結果だった
- 彼女は美容院で髪をセットしてもらった
- そのカセットには何も吹き込まれていない
- その番組を録画するためにビデオをセットした
- コーヒーセット一式
- 彼は印刷機をセットして昼食を食べに出かけた
- 彼らはブリッジを3セットやった
- 彼は第1セットを2‐6で失った
- シャンプーとセットをしてください
- 彼は新しいテレビセットを買った
- 舞台のセットは3つのいすと1本の木からなっていた
- 私はその外交販売員の口車に乗せられてスキンケア用の化粧品を1セット買わされた
- セット_(抽象データ型)のページへのリンク