blob: 5aaa4c1d48e33a1115dbbd62606b73c5f1bdc0f9 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
// Ackermann function
`export ack : Fn[m; n] $ (
t : `type m;
? |(t != `type n) {
`panic "m and n must be the same type"
}
? |(t = Int_signed; t = Float) {
? |(m < 0; n < 0) { `return 0 }
}
? {
m = 0 { n + 1 }
&(m > 0; n = 0) { ack `sync (m - 1; 1) }
{ ack `sync (m - 1; ack `sync (m; n - 1)) }
}
)
`export ack_string : Fn[m; n] $ (
"#MAGENTA#ack#(#CYAN#%#, #CYAN#%#) #WHITE#=# #GREEN#%#\n" `format (m; n; ack `sync (m; n))
)
`is_main Fn $ (
( args ) : `use "sys"
? 4 != `length args {
`return `error String $ (
"#BOLD#RED#Got: %#\n" `format `join args
"#BOLD#WHITE#Usage: % % <m> <n>#\n" `format (args `get 0; args `get 1)
)
}
`print ack_string `sync (U64 $ args `get -2; U64 $ args `get -1)
)
|