-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbig-oh.rb
36 lines (32 loc) · 840 Bytes
/
big-oh.rb
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
31
32
33
34
35
36
# convenience utility for double-checking Big-Oh complexity answers
# edit this file first!
#
# inside irb: `load "big-oh.rb"`
# using ruby: `ruby big-oh.rb`
# run test for first few numbers
# take the output and plug into OEIS.org to get the formula!
#
# in OS X Terminal, double-clicking on the comma-separated string will select
# it nicely for Cmd-C ;)
def bigOh
iterations = 6
1.upto(iterations) { |n| print methodA(n).to_s + (n != iterations ? "," : "") }
puts
end
# method to be tested, edit to insert/change loops as necessary
def methodA(n)
count = 0
for i in 1..n
for j in 1..i
count += f(j)
end
end
return count
end
# model the runtime of a function
# can be a constant (return 1) to measure number of times of execution
# or be proportional to the input parameter j
def f(j)
return j
end
bigOh