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
+7.6k Javascript : Put image into Chrome browser's console
+20.4k Golang : Saving private and public key to files
+14.2k Golang : GUI with Qt and OpenCV to capture image from camera
+4.4k Linux : sudo yum updates not working
+19.3k Golang : Close channel after ticker stopped example
+9.4k Golang : Sort and reverse sort a slice of floats
+10.7k Golang : Simple image viewer with Go-GTK
+19.6k Golang : Determine if directory is empty with os.File.Readdir() function
+7.1k Golang : Check to see if *File is a file or directory
+12k Golang : Flush and close file created by os.Create and bufio.NewWriter example
+4.8k Linux/Unix/MacOSX : Find out which application is listening to port 80 or use which IP version
+16.1k Golang :Trim white spaces from a string