#permutations #lexicographic #permutation #no-std #heaps-algorithm

no-std permutohedron

Generate permutations of sequences. Either lexicographical order permutations, or a minimal swaps permutation sequence implemented using Heap's algorithm.

13 releases

Uses old Rust 2015

0.2.4 Nov 11, 2017
0.2.3 Nov 11, 2017
0.2.2 Oct 12, 2016
0.2.1 Feb 16, 2016
0.1.4 Jun 30, 2015

#366 in Algorithms

Download history 5334/week @ 2024-09-22 4900/week @ 2024-09-29 4994/week @ 2024-10-06 4852/week @ 2024-10-13 4726/week @ 2024-10-20 4941/week @ 2024-10-27 5102/week @ 2024-11-03 4781/week @ 2024-11-10 4813/week @ 2024-11-17 4683/week @ 2024-11-24 5519/week @ 2024-12-01 5263/week @ 2024-12-08 5095/week @ 2024-12-15 1839/week @ 2024-12-22 1891/week @ 2024-12-29 4581/week @ 2025-01-05

13,702 downloads per month
Used in 97 crates (21 directly)

MIT/Apache

18KB
310 lines

permutohedron

Generate permutations of sequences.

Please read the API documentation here

build_status

How to use with cargo:

[dependencies]
permutohedron = "0.2"

Recent Changes

  • 0.2.4
    • Document a panic case in Heap::new that was not mentioned before
  • 0.2.3
    • Add license files to the repo and package, thanks to @ignatenkobrain
  • 0.2.2
    • Add trait ControlFlow and allow optionally terminating heap_recursive early.
  • 0.2.1
    • Add feature std (enabled by default) that allows you to opt out of using libstd.
  • 0.2.0
    • Add trait LexicalPermutation for lexicographical order of permutations, from Rust's libcore
  • 0.1.6
    • Small optimization of heap_recursive
  • 0.1.5
    • Cache-use / data layout optimizations for Heap
  • 0.1.4
    • Optimizations for Heap
  • 0.1.3
    • Fix an error in heap_recursive
  • 0.1.1
    • Add heap_recursive, a faster callback-based version of Heap's algorithm that can compute permutations of a sequence.
  • 0.1.0
    • Add Heap, an iterative walker & iterator using Heap's algorithm to compute permutations of a sequence.

License

Dual-licensed to be compatible with the Rust project.

Licensed under the Apache License, Version 2.0 http://www.apache.org/licenses/LICENSE-2.0 or the MIT license http://opensource.org/licenses/MIT, at your option. This file may not be copied, modified, or distributed except according to those terms.

No runtime deps

Features