トップQs
タイムライン
チャット
視点
セット (抽象データ型)
計算機科学における抽象データ型の一種 ウィキペディアから
Remove ads
セット(英: set)あるいは集合とは、コンピュータプログラミングで用いられる抽象データ型の一種。順序のないデータの集まりを表現する抽象データ型であり、同一のデータは一つしか含まれないことが保証される。
重複したデータの挿入
データの同一性は与えられた比較関数で判定されるので、外の文脈で同一かどうかは関数依存である。例えば文字列"hoge"と"HOGE"は異なるデータと見ることもできるし、大文字・小文字を区別せずに比較すれば(常に大文字化あるいは小文字化したもの同士を比較すれば)同一のデータと見ることもできるといった具合である。
そのような重複するデータを挿入しようとした場合はこれを処理する必要がある。
- 無視する
- 新しい物で置き換える
- 多重化する(→マルチセット参照)
狭義のセットにおいては重複データは無視されるか新しいデータで置き換えるかされる。もしここで多重化することを選択した場合は複数回の削除を行わなければ値は完全に取り除かれない。
アクセス速度は実装により様々だが、二分木(TreeSet)やハッシュテーブル(HashSet)などのデータ構造を用いて高速化を図ることが多い。
その他の抽象データ型との違い
各プログラミング言語におけるセット
- 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]
参照
関連項目
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads