// Based on Isaac Gouy's fannkuchredux.csharp use std; import std::int; import std::ivec; fn fannkuch(n: int) -> int { fn perm1init(i: uint) -> int { ret i as int; } let perm1init_ = perm1init; // Rustboot workaround let perm = ivec::init_elt_mut(0, n as uint); let perm1 = ivec::init_fn_mut(perm1init_, n as uint); let count = ivec::init_elt_mut(0, n as uint); let f = 0; let i = 0; let k = 0; let r = 0; let flips = 0; let nperm = 0; let checksum = 0; r = n; while r > 0 { i = 0; while r != 1 { count.(r - 1) = r; r -= 1; } while i < n { perm.(i) = perm1.(i); i += 1; } // Count flips and update max and checksum f = 0; k = perm.(0); while k != 0 { i = 0; while 2 * i < k { let t = perm.(i); perm.(i) = perm.(k - i); perm.(k - i) = t; i += 1; } k = perm.(0); f += 1; } if f > flips { flips = f; } if nperm & 0x1 == 0 { checksum += f; } else { checksum -= f; } // Use incremental change to generate another permutation let go = true; while go { if r == n { log checksum; ret flips; } let p0 = perm1.(0); i = 0; while i < r { let j = i + 1; perm1.(i) = perm1.(j); i = j; } perm1.(r) = p0; count.(r) -= 1; if count.(r) > 0 { go = false; } else { r += 1; } } nperm += 1; } ret flips; } fn main(args: vec[str]) { let n = 7; log #fmt("Pfannkuchen(%d) = %d", n, fannkuch(n)); }