Place these files in a lab5 folder. Before leaving lab, zip up the lab5 folder and hand the zip file in.
def search(list, key) index = 0 while index < list.length do if list[index] == key then return index end index = index + 1 end return nil endtiming linear search for 150 in Array(100...200)
Create an array whose elements contain the integers from 10,000 through 20,000, inclusive and set the variable big_list to contain that array.
Use the Rubylabs time { expr } construct to time how long it takes the search function above to find each of the following in big_list:
How long does each take?
If you repeat the same searches, does it take exactly the same amount of time? Why do you think this is?
How do you think the relationship between the position of the item you are searching for in the list and how long it takes to find that item?
Write your answers in a text file called timings.txt.
In mean.rb, write a Ruby function mean(list)to compute the arithmetic mean (or average) of a list of numbers.
Use the following algorithm:
Use floating point division as appropriate.
Example:
>> mean([1, -2, 3, 0, -4, -2, 7]) => 0.428571428571429
In bubble_sort.rb, write a Ruby function bsort!(list) that will arrange the elements of the array list in ascending order. (Note, the "!" is part of the name of the function. There is a convention among Ruby programmers to add exclamation points to the names of functions that modify their arguments or the object to which they belong.)
Use the following algorithm:
Example:
>> a = [1, -2, 3, 0, -4, -2, 7] => [1, -2, 3, 0, -4, -2, 7] >> bsort!(a) => nil >> a => [-4, -2, -2, 0, 1, 3, 7]
Challenge:
The above algorithm repeats step II.A.1 more times than is necessary. Modify your code to restrict the range of \(j\), so that unnecessary executions of II.A.1 are avoided.
(harder) In the algorithm given above, the number of times the loop is repeated is independent of the contents of list. Modify the algorithm so that it detects when list has become sorted and returns nil immediately.