This algorithm is quite fast and corect: public static int fibo(int n) { int t = 1; int result = 0;
while (n-- > 0) { result = t - result; t = t + result; } return result; } Am too busy to convert the code to Go, but it should be easy. Am Freitag, 25. Januar 2019 05:48:54 UTC+1 schrieb Ian Lance Taylor: > > On Thu, Jan 24, 2019 at 7:01 PM Karthik Krishnaswamy > <karthik.kri...@gmail.com <javascript:>> wrote: > > > > I am just curious to understand what is the best possible way to > increase the execution speed of this particular program ? I am still > learning go though :) > > To speed up that particular program, don't use recursive Fibonacci. > The recursive function that you wrote has complexity O(2 ** N). Write > a simple loop, complexity O(N). > > Ian > > > > On Fri, Jan 25, 2019 at 8:26 AM Ian Lance Taylor <ia...@golang.org > <javascript:>> wrote: > >> > >> On Thu, Jan 24, 2019 at 6:21 PM Topget <topge...@gmail.com > <javascript:>> wrote: > >> > > >> > I have tested several simple functions with Golang and Java. To my > surprise, Java sometimes is faster than Golang(especially in recursive > function and some function in standard library such as math/rand.Rand). I > wonder why. Here is some code I used for test and the result. > >> > >> Because goroutines start with a small stack that grows as needed, > >> deeply recursive functions will tend to have somewhat worse behavior > >> the first time they are called. > >> > >> Ian > >> > >> -- > >> You received this message because you are subscribed to the Google > Groups "golang-nuts" group. > >> To unsubscribe from this group and stop receiving emails from it, send > an email to golang-nuts...@googlegroups.com <javascript:>. > >> For more options, visit https://groups.google.com/d/optout. > -- You received this message because you are subscribed to the Google Groups "golang-nuts" group. To unsubscribe from this group and stop receiving emails from it, send an email to golang-nuts+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.