[![Build Status](https://travis-ci.org/darnir/capped_multiset.svg?branch=master)](https://travis-ci.org/darnir/capped_multiset)
[![Crates.io](https://img.shields.io/crates/v/capped_multiset.svg)](https://crates.io/crates/capped_multiset)
[![Crates.io](https://img.shields.io/crates/l/capped_multiset.svg)](./LICENSE)
[![Docs.rs](https://docs.rs/capped_multiset/badge.svg)](https://docs.rs/capped_multiset)
# CappedMultiset
A multiset is a datastructure which resembles a classic Set, except it allows duplicate
elements for each key. For more information on Multisets, see:
* [Wikipedia Entry](https://en.wikipedia.org/wiki/Multiset)
* [C++ Multisets](http://en.cppreference.com/w/cpp/container/multiset)
* [C++ Multiset Tutorial](http://www.java2s.com/Tutorial/Cpp/0380__set-multiset/Catalog0380__set-multiset.htm)
* _Knuth, Donald. The Art of Computer Programming Volume II, Section 4.6.3, Exercise 19_
This crate implements a `CappedMultiset`. A `CappedMultiset` is a datastructure similar to a
multiset, except it can have a dynamically defined "cap" on the value of each key. When such a
cap is defined, any operation to retrieve the value of an element of the set, the value
returned will be no greater than the "cap" on the multiset. This `cap` can be changed at
runtime and does not affect the actual data stored in the Multiset. As a result, setting
`cap = 1` or any other low value is not a lossy operation.
## Installation
```toml
[dependencies]
capped_multiset = "0.1"
```
## Example
```rust
extern crate capped_multiset;
use capped_multiset::CappedMultiset;
fn main() {
let set = vec![1, 2, 3, 4, 5];
let mut capped_set = CappedMultiset::new(set);
assert_eq!(capped_set.sum(), 15);
capped_set.set_cap(Some(1));
assert_eq!(capped_set.sum(), 5);
capped_set.set_cap(Some(2));
assert_eq!(capped_set.sum(), 9);
}
```
## License
MIT