Golang : Ackermann function example
Not really a tutorial, but just want to play with recursive function and toying with Ackermann function. Hope this example can be useful to you.
See http://en.wikipedia.org/wiki/Ackermann_function
package main
import (
"fmt"
"strconv"
"os"
)
func Ackermann(n, m int64) int64 {
// http://en.wikipedia.org/wiki/Ackermann_function
for n != 0 {
if m == 0 {
m = 1
} else {
m = Ackermann(n, m-1) // recursive
}
n = n - 1
}
return m + 1
}
func main() {
if len(os.Args) < 3 {
fmt.Println("[usage] : ackermann integer integer")
os.Exit(0)
}
// convert input (type string) to integer
first, err := strconv.ParseInt(os.Args[1], 10, 0)
if err != nil {
fmt.Println("First input parameter must be integer")
os.Exit(1)
}
second, err := strconv.ParseInt(os.Args[2], 10, 0)
if err != nil {
fmt.Println("Second input parameter must be integer")
os.Exit(1)
}
answer := Ackermann(first, second)
fmt.Println(answer)
}
Sample output :
./ackermnn 3
[usage] : ackermann integer integer
./ackermnn 3 2
29
References :
By Adam Ng
IF you gain some knowledge or the information here solved your programming problem. Please consider donating to the less fortunate or some charities that you like. Apart from donation, planting trees, volunteering or reducing your carbon footprint will be great too.
Advertisement
Tutorials
+23.7k Golang : Storing cookies in http.CookieJar example
+5.1k Golang : Selection sort example
+13.9k Golang : Find location by IP address and display with Google Map
+4.9k Golang : List all packages and search for certain package
+12.7k Golang : How to pass map to html template and access the map's elements
+10.9k Golang : List running EC2 instances and descriptions
+21.7k Golang : Randomly pick an item from a slice/array example
+20.5k Golang : Join arrays or slices example
+6.4k Golang : Example of how to detect which type of script a word belongs to
+4.5k Golang : Shortening import identifier
+10.4k Golang : flag provided but not defined error
+6.2k Golang : How to stop user from directly running an executable file?