3 releases
0.1.2 | Nov 10, 2018 |
---|---|
0.1.1 | Nov 10, 2018 |
0.1.0 | Nov 10, 2018 |
#217 in #recursion
14KB
262 lines
The #[reciter]
attribute macro allows converting a recursive function into an Iterator, which uses a cache.
Example
#[reciter(cache = "auto", start = 1)]
fn factorial(n: usize) -> BigInt {
if n == 1 {
BigInt::from(1)
} else {
n * factorial(n - 1)
}
}
fn main() {
let fi = FactorialIterator::new();
for (i, fac) in fi.enumerate().take(512) {
println!("{}! = {}", i + 1, fac);
}
}
For more information look into the documentation or at the tests in the repository.
Dependencies
~2MB
~50K SLoC