import algolab
import sys
#sys.path.append('../exams/2017-06-08-lab/solutions')
sys.path.append('past-exams/2017-06-08/solutions')
import nxpd
algolab.init()
There won't be any internet access. You will only be able to access:
One bonus point can be earned by writing stylish code. You got style if you:
avoid convoluted code like i.e.
if x > 5:
return True
else:
return False
when you could write just
return x > 5
%%HTML
<p class="algolab-warn">
!!!!!!!!! WARNING !!!!!!!!!
<br/>
<br/>
!!!!!!!!! **ONLY** IMPLEMENTATIONS OF THE PROVIDED FUNCTION SIGNATURES WILL BE EVALUATED !!!!!!!!! <br/>
</p>
For example, if you are given to implement:
def cool_fun(x):
raise Exception("TODO implement me")
and you ship this code:
def cool_fun_non_working_trial(x):
# do some absurdity
def cool_fun_a_perfectly_working_trial(x):
# a super fast, correct and stylish implementation
def cool_fun(x):
raise Exception("TODO implement me")
We will assess only the latter one cool_fun(x)
, and conclude it doesn't work at all :P !!!!!!!
Still, you are allowed to define any extra helper function you might need. If your cool_fun(x)
implementation calls some other function you defined like my_helper
here, it is ok:
def my_helper(y,z):
# do something useful
def cool_fun(x):
my_helper(x,5)
# this will get ignored:
def some_trial(x):
# do some absurdity
In /usr/local/esame you should find a file named algolab-17-06-08.zip
. Download it and extract it on your desktop. The content should be like this:
algolab-17-06-08
|- FIRSTNAME-LASTNAME-ID
|- exercise1.py
|- exercise2.py
|- exercise3.py
2) Check this folder also shows under /var/exam
. TODO
3) Rename FIRSTNAME-LASTNAME-ID
folder: put your name, lastname an id number, like john-doe-432432
From now on, you will be editing the files in that folder. At the end of the exam, that is what will be evaluated.
4) Edit the files following the instructions in this worksheet for each exercise.
%%HTML
<p class="algolab-warn">
WARNING: <i>DON'T</i> modify function signatures! Just provide the implementation.
</p>
<p class="algolab-warn">
WARNING: <i>DON'T</i> change the existing test methods, just add new ones !!! You can add as many as you want.
</p>
<p class="algolab-warn">
WARNING: <i>DON'T</i> create other files. If you still do it, they won't be evaluated.
</p>
<p class="algolab-important">
IMPORTANT: Pay close attention to the comments of the functions.
</p>
<p class="algolab-important">
IMPORTANT: if you need to print some debugging information, you <i>are allowed</i> to put extra <code>print</code>
statements in the function bodies.
</p>
<p class="algolab-warn">
WARNING: even if <code>print</code> statements are allowed, be careful with prints that might
break your function, i.e. avoid stuff like this: <code> print 1/0 </code>
</p>
3) Every exercise should take max 25 mins. If it takes longer, leave it and try another exercise.
%%HTML
<p class="algolab-warn">
WARNING: MAKE SURE ALL EXERCISE FILES AT LEAST COMPILE !!! <br/> 10 MINS BEFORE THE END
OF THE EXAM I WILL ASK YOU TO DO A FINAL CLEAN UP OF THE CODE
</p>
You are given a class SortedStack
that models a simple stack. This stack is similar to the CappedStack
you already saw in class, the differences being:
ValueError
Example:
Ascending: Descending
8 3
5 5
3 8
from exercise1_solution import *
To create a SortedStack
sorted in ascending order, just call it passing True
:
s = SortedStack(True)
print s
s.push(5)
print s
s.push(7)
print s
print s.pop()
print s
print s.pop()
print s
For descending order, pass False
when you create it:
sd = SortedStack(False)
sd.push(7)
sd.push(5)
sd.push(4)
print(sd)
SortedStack
¶Now open the file exercise1.py
andcheck your environment is working fine, by trying to run the tests only for SortedStackTest
, which tests already implemented methods like pop
, push
, etc ... : these tests should all pass, if they don't, tell your instructor.
Notice that exercise1
is followed by a dot and test class name: .SortedStackTest
python -m unittest exercise1.SortedStackTest
algolab.run(SortedStackTest)
transfer
¶Now implement the transfer
function. NOTE: function is external to class SortedStack
.
def transfer(s):
""" Takes as input a SortedStack s (either ascending or descending) and
returns a new SortedStack with the same elements of s, but in reverse order.
At the end of the call s will be empty.
Example:
s result
2 5
3 3
5 2
"""
raise Exception("TODO IMPLEMENT ME !!")
Testing
Once done, running this will run only the tests in TransferTest
class and hopefully they will pass.
Notice that exercise1
is followed by a dot and test class name .TransferTest
:
python -m unittest exercise1.TransferTest
algolab.run(TransferTest)
merge
¶Implement following merge
function. NOTE: function is external to class SortedStack
.
def merge(s1,s2):
""" Takes as input two SortedStacks having both ascending order,
and returns a new SortedStack sorted in descending order, which will be the sorted merge
of the two input stacks. MUST run in O(n1 + n2) time, where n1 and n2 are s1 and s2 sizes.
If input stacks are not both ascending, raises ValueError.
At the end of the call the input stacks will be empty.
Example:
s1 (asc) s2 (asc) result (desc)
5 7 2
4 3 3
2 4
5
7
"""
raise Exception("TODO IMPLEMENT ME !")
Testing: python -m unittest exercise1.MergeTest
algolab.run(MergeTest)
Start editing file exercise2.py
, which contains a simplified versioned of the UnorderedList
we saw in the labs.
from exercise2_solution import *
panino
¶Implement following panino
function. NOTE: the function is external to class UnorderedList
.
def panino(lst):
""" Returns a new UnorderedList having double the nodes of provided lst
First nodes will have same elements of lst, following nodes will
have the same elements but in reversed order.
For example:
>>> panino(['a'])
UnorderedList: a,a
>>> panino(['a','b'])
UnorderedList: a,b,b,a
>>> panino(['a','c','b'])
UnorderedList: a,c,b,b,c,a
"""
raise Exception("TODO IMPLEMENT ME !")
Testing: python -m unittest exercise2.PaninoTest
algolab.run(PaninoTest)
norep
¶Implement the method norep
:
def norep(self):
""" Removes all the consecutive repetitions from the list.
Must perform in O(n), where n is the list size.
For example, after calling norep:
'a','a','b','c','c','c' will become 'a','b','c'
'a','a','b','a' will become 'a','b','a'
"""
raise Exception("TODO IMPLEMENT ME !")
Testing: python -m unittest exercise2.NorepTest
algolab.run(NorepTest)
Start editing file exercise3.py
, which contains a simplified versioned of the GenericTree
we saw in the labs.
from exercise3_solution import *
Implement the method ancestors
:
def ancestors(self):
""" Return the ancestors up until the root as a Python list.
First item in the list will be the parent of this node.
NOTE: this function return the *nodes*, not the data.
"""
raise Exception("TODO IMPLEMENT ME !")
Testing: python -m unittest exercise3.AncestorsTest
Examples:
- ancestors of p: f, b, a
- ancestors of h: c, a
- ancestors of a: empty list
algolab.run(GenericTreeTest)
algolab.run(AncestorsTest)
Implement the method leftmost
:
def leftmost(self):
"""
Return the leftmost node of the root of this node. To find it, from
current node you need to reach the root of the tree and then from
the root you need to follow the _child chain until a node with no children is found.
If self is already the root, or the root has no child, raises LookupError.
NOTE: this function return a *node*, not the data.
"""
raise Exception("TODO IMPLEMENT ME !")
Testing: python -m unittest exercise3.LeftmostTest
Examples:
- leftmost of p: e
- leftmost of h: e
- leftmost of e: raise LookupError
algolab.run(LeftmostTest)
Implement the method common_ancestor
:
def common_ancestor(self, gt2):
""" Return the first common ancestor of current node and the provided gt2 node
If gt2 is not a node of the same tree, raises LookupError
NOTE: this function returns a *node*, not the data.
Ideally, this method should perform in O(h) where h is the height of the tree.
(Hint: you should use a Python Set). If you can't figure out how to make it
that fast, try to make it at worst O(h^2)
"""
raise Exception("TODO IMPLEMENT ME !")
Testing: python -m unittest exercise3.CommonAncestorTest
Examples:
- common ancestor of g and i: c
- common_ancestor of g and q: c
- common_ancestor of e and d: a
algolab.run(CommonAncestorTest)