Download code

From LiteratePrograms

Jump to: navigation, search

Back to Fibonacci_numbers_(Oz)

Download for Windows: single file, zip

Download for UNIX: single file, zip, tar.gz, tar.bz2

Fib.oz

 1 % Copyright (c) 2008 the authors listed at the following URL, and/or
 2 % the authors of referenced articles or incorporated external code:
 3 % http://en.literateprograms.org/Fibonacci_numbers_(Oz)?action=history&offset=20080201070240
 4 % 
 5 % Permission is hereby granted, free of charge, to any person obtaining
 6 % a copy of this software and associated documentation files (the
 7 % "Software"), to deal in the Software without restriction, including
 8 % without limitation the rights to use, copy, modify, merge, publish,
 9 % distribute, sublicense, and/or sell copies of the Software, and to
10 % permit persons to whom the Software is furnished to do so, subject to
11 % the following conditions:
12 % 
13 % The above copyright notice and this permission notice shall be
14 % included in all copies or substantial portions of the Software.
15 % 
16 % THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
17 % EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18 % MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
19 % IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
20 % CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
21 % TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
22 % SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
23 % 
24 % Retrieved from: http://en.literateprograms.org/Fibonacci_numbers_(Oz)?oldid=12457
25 
26 functor
27 import
28    System
29    Application
30 define
31    fun {RecursiveFib N}
32       if N < 2 then N else {RecursiveFib N - 1} + {RecursiveFib N - 2} end
33    end
34 
35    Memo = {NewDictionary}
36    fun {MemoizedFib N}
37       if {Dictionary.member Memo N}
38       then {Dictionary.get Memo N}
39       else
40          FibN
41       in
42          if N < 2 then FibN = N else FibN = {MemoizedFib N - 1} + {MemoizedFib N - 2} end
43          {Dictionary.put Memo N FibN}
44          FibN
45       end
46    end
47 
48    fun {IterativeFib N}
49       fun {Fib N F1 F2}
50         if N < 1 then F1 else {Fib (N - 1) F2 (F1 + F2)} end
51       end
52    in
53       {Fib N 0 1}
54    end
55 
56    proc {RunFib F}
57       for X in 0..30 do
58          {System.showInfo "{" # {System.printName F} # " " # X # "} = " # {F X}}
59       end
60    end
61 
62    {RunFib RecursiveFib}
63    {RunFib MemoizedFib}
64    {RunFib IterativeFib}
65    {Application.exit 0}
66 
67 end
68 


Views
Personal tools