capped_multiset 0.1.0

A Multiset that can return a capped value on the elements
Documentation
[![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