Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sundy-li/partial_sort
partial_sort is Rust version of [std::partial_sort](https://en.cppreference.com/w/cpp/algorithm/partial_sort)
https://github.com/sundy-li/partial_sort
Last synced: about 2 months ago
JSON representation
partial_sort is Rust version of [std::partial_sort](https://en.cppreference.com/w/cpp/algorithm/partial_sort)
- Host: GitHub
- URL: https://github.com/sundy-li/partial_sort
- Owner: sundy-li
- Created: 2021-02-25T13:36:07.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2023-02-27T01:21:46.000Z (almost 2 years ago)
- Last Synced: 2024-04-24T15:13:40.100Z (8 months ago)
- Language: Rust
- Size: 26.4 KB
- Stars: 16
- Watchers: 2
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# partial_sort
[![Build Status](https://github.com/sundy-li/partial_sort/actions/workflows/Build.yml/badge.svg)](https://github.com/sundy-li/partial_sort/actions/workflows/Build.yml)
[![](http://meritbadge.herokuapp.com/partial_sort)](https://crates.io/crates/partial_sort)
[![](https://img.shields.io/crates/d/partial_sort.svg)](https://crates.io/crates/partial_sort)
[![](https://img.shields.io/crates/dv/partial_sort.svg)](https://crates.io/crates/partial_sort)
[![](https://docs.rs/partial_sort/badge.svg)](https://docs.rs/partial_sort/)partial_sort is Rust version of [std::partial_sort](https://en.cppreference.com/w/cpp/algorithm/partial_sort)
## Usage
```rust
use partial_sort::PartialSort;fn main() {
let mut vec = vec![4, 4, 3, 3, 1, 1, 2, 2];
vec.partial_sort(4, |a, b| a.cmp(b));
println!("{:?}", vec);
}```
## Benches
First we compare what happens when sorting the entire vector (in Macbook pro M1Max):```
partial sort 10000 limit 20 time: [5.2093 µs 5.2470 µs 5.2892 µs]
partial sort 10000 limit 200 time: [15.742 µs 16.116 µs 16.645 µs]
partial sort 10000 limit 2000 time: [117.99 µs 119.59 µs 121.32 µs]
partial sort 10000 limit 10000 time: [281.40 µs 287.69 µs 295.43 µs]
stdsort 10000 time: [363.75 µs 366.93 µs 371.06 µs]
heapsort 10000 time: [253.89 µs 256.02 µs 258.35 µs]partial reverse sort 10000 limit 20 time: [5.7620 µs 6.0627 µs 6.5347 µs]
stdsort reverse 10000 time: [347.39 µs 355.88 µs 369.46 µs]
```## License
Licensed under either of
* Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)