mirror of
https://github.com/emirpasic/gods
synced 2024-11-18 09:25:50 +00:00
26 lines
943 B
Go
26 lines
943 B
Go
// Copyright (c) 2015, Emir Pasic. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
// Package sets provides an abstract Set interface.
|
|
//
|
|
// In computer science, a set is an abstract data type that can store certain values and no repeated values. It is a computer implementation of the mathematical concept of a finite set. Unlike most other collection types, rather than retrieving a specific element from a set, one typically tests a value for membership in a set.
|
|
//
|
|
// Reference: https://en.wikipedia.org/wiki/Set_%28abstract_data_type%29
|
|
package sets
|
|
|
|
import "github.com/emirpasic/gods/containers"
|
|
|
|
// Set interface that all sets implement
|
|
type Set interface {
|
|
Add(elements ...interface{})
|
|
Remove(elements ...interface{})
|
|
Contains(elements ...interface{}) bool
|
|
|
|
containers.Container
|
|
// Empty() bool
|
|
// Size() int
|
|
// Clear()
|
|
// Values() []interface{}
|
|
}
|