summary refs log tree commit diff
path: root/src/test/bench/shootout-ackermann.rs
blob: a27195eb900e5400e9e833bedd3f1c51a92df575 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
use std;

fn ack(m: int, n: int) -> int {
    if m == 0 {
        ret n + 1
    } else {
        if n == 0 {
            ret ack(m - 1, 1);
        } else {
            ret ack(m - 1, ack(m, n - 1));
        }
    }
}

fn main(args: [str]) {
    let n = if vec::len(args) == 2u {
        option::get(int::from_str(args[1]))
    } else {
        8
    };
    io::println(#fmt("Ack(3,%d): %d\n", n, ack(3, n)));
}