Fall 2022 Ruby Exam
Problem 1
Write a function crank
that gets a line of input from the user and then displays it uppercase and cranked 45 degrees clockwise. For example, if the user enters sock
, this is the output:
S
O
C
K
S O C K
Each character is succeeded by a linebreak.
Problem 2
Write a class Datums
whose constructor accepts an array of numbers. Its method mean
gives the average number. Its method median
gives the number that would appear in the middle of the list if it were sorted. If the list has no single middle element, it gives back the number halfway between the two middle elements. Its method numbers
gives back the array in the exact same form that it was given to the constructor.
Assume the array contains at least one number.
Problem 3
Suppose you've got one hash that maps names to jobs. Then you've got another hash that maps jobs to salaries. You want a hash that maps names to salaries. Write a function jump_hash
that accepts two hashes and returns a hash that maps the keys of the first to the values of the second. For example, jump_hash({'Trina' => 'astronaut'}, {'astronaut' => 200000})
→ {'Trina' => 200000}
.
Problem 4
Write a class Book
with a constructor that accepts a title and author. Give it getters.
Also, say you've got an array of arrays in which each inner array has two elements: a book title and an author name. You want an array of Book
objects. Write a top-level method embooks
that receives the array and returns an array of Book
instances. Use higher-order functions; do not use each
or a for
loop.
Problem 5
Suppose you are given an array of people. Each person is represented as a hash with keys :first
and :last
. Write a function five_lasts
that receives such an array and returns an array of the last names of the people whose first names are five characters or fewer.
Use higher-order functions; do not use each
or a for
loop.
Problem 6
Write a function trade
that reads from the first line of input a list of numbers separated by spaces. On the second line is a number \(n\) of trades that are to occur. On the remaining \(n\) lines are pairs of indices. The function swaps the elements indicated by each pair and returns the array after all swaps have been applied. For example, suppose you have this input:
4 9 7 -6
2
0 1
1 3
4 9 7 -6 2 0 1 1 3
The array [9, -6, 7, 4]
is returned.