Download code
From LiteratePrograms
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
