File: recursion.t

package info (click to toggle)
nqp 2014.07-3
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 23,596 kB
  • ctags: 7,993
  • sloc: ansic: 22,689; java: 20,240; cpp: 4,956; asm: 3,976; perl: 950; python: 267; sh: 245; makefile: 14
file content (30 lines) | stat: -rwxr-xr-x 580 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
puts "1..2"

def fact!(n)
    if n <= 1 then
       1
    else
       n * fact!(n - 1)
    end
end

result = fact!(6)
expected =  6*5*4*3*2

puts "#{result == expected ? 'ok' : 'nok'} 1 - sub recursion"

# ----------

class MethodRecursion
    def fibonacci(n)
        n <= 1  \
            ? n \
            : self.fibonacci( n - 1 ) + fibonacci(n - 2 ) 
## 2 styles:  ^^ explicit method call   ^^ implied method call
    end
end

fib = MethodRecursion.new.fibonacci(9)
expected2 = 34

puts "#{fib == expected2 ? 'ok' : 'nok'} 2 - method recursion"