Difference between revisions of "CSC111 Homework 10 2011"
(→Your assignment) |
|||
(7 intermediate revisions by the same user not shown) | |||
Line 2: | Line 2: | ||
---- | ---- | ||
<bluebox> | <bluebox> | ||
− | This is an A/E type of homework. You have several problems to solve. You either get an A or an E on each one. What is important here is Python, not documentation or robustness (this is an exception to the rule). You have to solve different problems and make your program output the correct answer. Correct answers get A, incorrect ones get E. I will not read the code closely and take point for lack of documentation, and I will not try to make your program crash to test its robustness. | + | This is an A/E type of homework. You have several problems to solve. You either get an A or an E on each one. What is important here is Python, not documentation or robustness (this is an exception to the rule!--pun intended!). You have to solve different problems and make your program output the correct answer. Correct answers get A, incorrect ones get E. I will not read the code closely and take point for lack of documentation, and I will not try to make your program crash to test its robustness. |
<br /> | <br /> | ||
The main goal for this particular assignment is for you to use classes and objects and make them work. | The main goal for this particular assignment is for you to use classes and objects and make them work. | ||
Line 24: | Line 24: | ||
:(we assume that '''car''' is an ''object'' instantiated from the ''class'' Car.) | :(we assume that '''car''' is an ''object'' instantiated from the ''class'' Car.) | ||
− | * Make your program implement this loop so that we can see the car move out of the window. | + | * Make your program implement this loop so that we can see the car move out of the graphic window. |
+ | |||
+ | ==Submission== | ||
+ | |||
* Store your program in a file called '''hw10a.py''' and submit it this way: | * Store your program in a file called '''hw10a.py''' and submit it this way: | ||
− | rsubmit hw10 hw10a.py | + | rsubmit hw10 hw10a.py |
− | :or use the http://cs.smith.edu/~111a/submit10.htm submit form. | + | : if you are working on beowulf or use the http://cs.smith.edu/~111a/submit10.htm submit form. |
<br /> | <br /> | ||
Line 87: | Line 90: | ||
</source> | </source> | ||
− | * | + | * This code is not documented, and for this homework documentation is not required. |
− | * Note how each ball remembers its direction of movement in the two ''member variables'' self.dx and self.dy. | + | * Note how each ball remembers its direction of movement in the two ''member variables'' '''self.dx''' and '''self.dy'''. |
==Assignment== | ==Assignment== | ||
− | * Add a new method | + | * Add a new method to the '''Ball''' class called '''changeDirIfHittingWall()'''. This method changes the sign of '''self.dx''' or of '''self.dy''' when the ball hits a vertical or horizontal wall (the boundaries of the window). For example, when the ball hits a vertical wall, then the method will change self.dx to be -self.dx. |
* If your method is written correctly, the main function below will see the balls bouncing off all the windows borders in a natural fashion, in a way similar to what we have done many times before. | * If your method is written correctly, the main function below will see the balls bouncing off all the windows borders in a natural fashion, in a way similar to what we have done many times before. | ||
<br /> | <br /> | ||
Line 123: | Line 126: | ||
<br /> | <br /> | ||
==Additional Information== | ==Additional Information== | ||
− | * the balls must bounce off '''all''' four borders of the window | + | * the balls must bounce off '''all''' four borders of the window. |
− | * the balls do not have to bounce off each other | + | * the balls do not have to bounce off each other. |
==Submission== | ==Submission== | ||
Line 132: | Line 135: | ||
= Problem 3= | = Problem 3= | ||
− | * And you thought we were done with the presidents! | + | * And you thought we were done with the presidents!... |
* Play with the code below: | * Play with the code below: | ||
+ | <br /> | ||
+ | <br /> | ||
<source lang="python"> | <source lang="python"> | ||
presidents = \ | presidents = \ | ||
Line 248: | Line 253: | ||
</source> | </source> | ||
+ | <br /> | ||
+ | <br /> | ||
==Your assignment== | ==Your assignment== | ||
===Part 1=== | ===Part 1=== | ||
* For this part you cannot modify the President class. | * For this part you cannot modify the President class. | ||
− | |||
− | |||
* Make the main program output the number of democratic presidents, the number of republican presidents, and the number of "other" party presidents. | * Make the main program output the number of democratic presidents, the number of republican presidents, and the number of "other" party presidents. | ||
+ | * You can only modify the '''main()''' function. | ||
+ | * Whatever you do, you cannot use the string '''presidents''' again, once it has been processed by '''createListOfPres()'''. | ||
+ | |||
===Part 2=== | ===Part 2=== | ||
* For this part you can add new methods to the President class. | * For this part you can add new methods to the President class. | ||
− | * You cannot | + | * You cannot use the string '''presidents''' once '''createListOfPres()''' has parsed it. |
− | * Make your program prompt the user for a year, and output the president or presidents who was/were | + | * Make your program prompt the user for a year, and output the president or presidents who was/were on active duty that year. |
− | * It is fine if your program does not output '''Obama''' for 2011, but it is nice if it does! | + | * It is fine (no penalty) if your program does not output '''Obama''' for 2011, but it is nice if it does! |
==Submission== | ==Submission== | ||
Line 265: | Line 273: | ||
=Problem 4= | =Problem 4= | ||
+ | [[Image:MeanCat.jpg|right|150px]] | ||
+ | ==Your assignment== | ||
+ | * My cat ate my program! Yes, she did! I had a nicely written (though not documented) program, was ready to show it to you, but my cat ate part of it. | ||
+ | * The good part is: I kept a copy of the program's output when it was still in its complete state: | ||
+ | |||
+ | <code><pre> | ||
+ | Cheetah 70.0 mph | ||
+ | Pronghorn Antelope 61.0 mph | ||
+ | Wildebeest 50.0 mph | ||
+ | Lion 50.0 mph | ||
+ | Thomson's Gazelle 50.0 mph | ||
+ | Quarter Horse 47.5 mph | ||
+ | Elk 45.0 mph | ||
+ | Cape Hunting Dog 45.0 mph | ||
+ | Coyote 43.0 mph | ||
+ | Gray Fox 42.0 mph | ||
+ | Hyena 40.0 mph | ||
+ | Zebra 40.0 mph | ||
+ | Mongolian Wild Ass 40.0 mph | ||
+ | Greyhound 39.4 mph | ||
+ | Whippet 35.5 mph | ||
+ | Rabbit (domestic) 35.0 mph | ||
+ | Mule Deer 35.0 mph | ||
+ | Jackal 35.0 mph | ||
+ | Reindeer 32.0 mph | ||
+ | Giraffe 32.0 mph | ||
+ | White-Tailed Deer 30.0 mph | ||
+ | Warthog 30.0 mph | ||
+ | Grizzly Bear 30.0 mph | ||
+ | Cat (domestic) 30.0 mph | ||
+ | Human 27.9 mph | ||
+ | Elephant 25.0 mph | ||
+ | Black Mamba Snake 20.0 mph | ||
+ | Six-Lined Racerunner 18.0 mph | ||
+ | Wild Turkey 15.0 mph | ||
+ | Squirrel 12.0 mph | ||
+ | Pig (domestic) 11.0 mph | ||
+ | Chicken 9.0 mph | ||
+ | Spider (Tegenaria atrica) 1.2 mph | ||
+ | Giant Tortoise 0.2 mph | ||
+ | Three-Toed Sloth 0.1 mph | ||
+ | Garden Snail 0.0 mph | ||
+ | Fastest animal: Cheetah | ||
+ | Slowest animal: Garden Snail | ||
+ | Closest to 0 miles/hour: Garden Snail 0.03 mph | ||
+ | Closest to 3 miles/hour: Spider (Tegenaria atrica) 1.17 mph | ||
+ | Closest to 6 miles/hour: Chicken 9 mph | ||
+ | Closest to 9 miles/hour: Chicken 9 mph | ||
+ | Closest to 12 miles/hour: Squirrel 12 mph | ||
+ | Closest to 15 miles/hour: Wild Turkey 15 mph | ||
+ | Closest to 18 miles/hour: Six-Lined Racerunner 18 mph | ||
+ | Closest to 21 miles/hour: Black Mamba Snake 20 mph | ||
+ | Closest to 24 miles/hour: Elephant 25 mph | ||
+ | Closest to 27 miles/hour: Human 27.89 mph | ||
+ | Closest to 30 miles/hour: Cat (domestic) 30 mph | ||
+ | Closest to 33 miles/hour: Giraffe 32 mph | ||
+ | Closest to 36 miles/hour: Whippet 35.5 mph | ||
+ | Closest to 39 miles/hour: Greyhound 39.35 mph | ||
+ | Closest to 42 miles/hour: Gray Fox 42 mph | ||
+ | Closest to 45 miles/hour: Cape Hunting Dog 45 mph | ||
+ | Closest to 48 miles/hour: Quarter Horse 47.5 mph | ||
+ | </pre></code> | ||
+ | <br /> | ||
+ | <br /> | ||
+ | * Unfortunately all I can reassemble from the pieces of paper I could get back from the tiger's claws is this: | ||
+ | <br /> | ||
+ | <br /> | ||
+ | |||
+ | <source lang="python"> | ||
+ | animalSpeed = """Cheetah 70 | ||
+ | Pronghorn Antelope 61 | ||
+ | Wildebeest 50 | ||
+ | Lion 50 | ||
+ | Thomson's Gazelle 50 | ||
+ | |||
+ | Spider (Tegenaria atrica) 1.17 | ||
+ | Giant Tortoise 0.17 | ||
+ | Three-Toed Sloth 0.15 | ||
+ | Garden Snail 0.03""" | ||
+ | |||
+ | class AnimalList: | ||
+ | def __init__( self ): | ||
+ | self.List = [] | ||
+ | |||
+ | def append( self, animal, speed): | ||
+ | self.List.append( [ ] ) | ||
+ | |||
+ | def get( self, index ): | ||
+ | if 0 <= index < len( self.List ): | ||
+ | speed, animal = self.List[ index ] | ||
+ | return animal, speed | ||
+ | return None, None | ||
+ | |||
+ | def size( self ): | ||
+ | return len( self.List ) | ||
+ | |||
+ | def sort( self ): | ||
+ | ... | ||
+ | |||
+ | def reverse( self ): | ||
+ | self.List.reverse() | ||
+ | |||
+ | def getFastest( self ): | ||
+ | self.sort() | ||
+ | if len( self.List )> 0: | ||
+ | speed, animal = self.List[ -1 ] | ||
+ | return animal, speed | ||
+ | return None, None | ||
+ | |||
+ | def topN( self, n ): | ||
+ | return self.List[-n: ] | ||
+ | |||
+ | def closestInSpeedTo( self, targetSpeed ): | ||
+ | if len( self.List )==0: | ||
+ | return None, None | ||
+ | closestSpeed, closestAnimal = self.List[0] | ||
+ | for speed, animal in self.List: | ||
+ | if abs( targetSpeed - closestSpeed ) > abs( targetSpeed - speed ): | ||
+ | closestSpeed = speed | ||
+ | closestAnimal = animal | ||
+ | return closestAnimal, closestSpeed | ||
+ | |||
+ | def main(): | ||
+ | animals = AnimalList() | ||
+ | |||
+ | for line in animalSpeed.split( '\n' ): | ||
+ | words = line.split() | ||
+ | speed = | ||
+ | animal = | ||
+ | animals.append( animal, speed ) | ||
+ | |||
+ | for i in range( animals.size() ): | ||
+ | animal, speed = animals.get( i ) | ||
+ | print( "%30s %10.1f mph" % (animal, speed ) ) | ||
+ | |||
+ | |||
+ | animal, speed = animals.getSlowest() | ||
+ | print( "Slowest animal: ", animal ) | ||
+ | |||
+ | for target in range( 0, 50, 3 ): | ||
+ | animal, speed = animals.closestInSpeedTo( target ) | ||
+ | print( "Closest to", target," miles/hour:", animal, speed, "mph" ) | ||
+ | |||
+ | |||
− | + | main() | |
+ | |||
+ | </source> | ||
<br /> | <br /> | ||
+ | <br /> | ||
+ | * Figure out what code is missing so that the output of your program matches '''exactly''' the output shown above. | ||
+ | ==Submission== | ||
+ | * call your program '''hw10d.py''' and submit it as illustrated in Problem 1 above. | ||
+ | <br /> | ||
+ | <br /> | ||
+ | <onlydft> | ||
+ | <source lang="python"> | ||
+ | animalSpeed = """Cheetah 70 | ||
+ | Pronghorn Antelope 61 | ||
+ | Wildebeest 50 | ||
+ | Lion 50 | ||
+ | Thomson's Gazelle 50 | ||
+ | Quarter Horse 47.5 | ||
+ | Elk 45 | ||
+ | Cape Hunting Dog 45 | ||
+ | Coyote 43 | ||
+ | Gray Fox 42 | ||
+ | Hyena 40 | ||
+ | Zebra 40 | ||
+ | Mongolian Wild Ass 40 | ||
+ | Greyhound 39.35 | ||
+ | Whippet 35.5 | ||
+ | Rabbit (domestic) 35 | ||
+ | Mule Deer 35 | ||
+ | Jackal 35 | ||
+ | Reindeer 32 | ||
+ | Giraffe 32 | ||
+ | White-Tailed Deer 30 | ||
+ | Warthog 30 | ||
+ | Grizzly Bear 30 | ||
+ | Cat (domestic) 30 | ||
+ | Human 27.89 | ||
+ | Elephant 25 | ||
+ | Black Mamba Snake 20 | ||
+ | Six-Lined Racerunner 18 | ||
+ | Wild Turkey 15 | ||
+ | Squirrel 12 | ||
+ | Pig (domestic) 11 | ||
+ | Chicken 9 | ||
+ | Spider (Tegenaria atrica) 1.17 | ||
+ | Giant Tortoise 0.17 | ||
+ | Three-Toed Sloth 0.15 | ||
+ | Garden Snail 0.03""" | ||
+ | |||
+ | class AnimalList: | ||
+ | def __init__( self ): | ||
+ | self.List = [] | ||
+ | |||
+ | def append( self, animal, speed): | ||
+ | self.List.append( [speed, animal] ) | ||
+ | |||
+ | def get( self, index ): | ||
+ | if 0 <= index < len( self.List ): | ||
+ | speed, animal = self.List[ index ] | ||
+ | return animal, speed | ||
+ | return None, None | ||
+ | |||
+ | def size( self ): | ||
+ | return len( self.List ) | ||
+ | |||
+ | def sort( self ): | ||
+ | self.List.sort() | ||
+ | |||
+ | def reverse( self ): | ||
+ | self.List.reverse() | ||
+ | |||
+ | def getFastest( self ): | ||
+ | self.sort() | ||
+ | if len( self.List )> 0: | ||
+ | speed, animal = self.List[ -1 ] | ||
+ | return animal, speed | ||
+ | return None, None | ||
+ | |||
+ | def getSlowest( self ): | ||
+ | self.sort() | ||
+ | if len( self.List )> 0: | ||
+ | speed, animal = self.List[ 0 ] | ||
+ | return animal, speed | ||
+ | return None, None | ||
+ | |||
+ | def topN( self, n ): | ||
+ | return self.List[-n: ] | ||
+ | |||
+ | def closestInSpeedTo( self, targetSpeed ): | ||
+ | if len( self.List )==0: | ||
+ | return None, None | ||
+ | closestSpeed, closestAnimal = self.List[0] | ||
+ | for speed, animal in self.List: | ||
+ | if abs( targetSpeed - closestSpeed ) > abs( targetSpeed - speed ): | ||
+ | closestSpeed = speed | ||
+ | closestAnimal = animal | ||
+ | return closestAnimal, closestSpeed | ||
+ | |||
+ | def main(): | ||
+ | animals = AnimalList() | ||
+ | |||
+ | for line in animalSpeed.split( '\n' ): | ||
+ | words = line.split() | ||
+ | speed = eval( words[-1] ) | ||
+ | animal = ' '.join( words[0:-1] ) | ||
+ | animals.append( animal, speed ) | ||
+ | |||
+ | for i in range( animals.size() ): | ||
+ | animal, speed = animals.get( i ) | ||
+ | print( "%30s %10.1f mph" % (animal, speed ) ) | ||
+ | |||
+ | animal, speed = animals.getFastest() | ||
+ | print( "Fastest animal: ", animal ) | ||
+ | |||
+ | animal, speed = animals.getSlowest() | ||
+ | print( "Slowest animal: ", animal ) | ||
+ | |||
+ | for target in range( 0, 50, 3 ): | ||
+ | animal, speed = animals.closestInSpeedTo( target ) | ||
+ | print( "Closest to", target," miles/hour:", animal, speed, "mph" ) | ||
+ | |||
+ | |||
+ | |||
+ | main() | ||
+ | |||
+ | </source> | ||
+ | </onlydft> | ||
[[Category:CSC111]][[Category:Python]][[Category:Homework]] | [[Category:CSC111]][[Category:Python]][[Category:Homework]] |
Latest revision as of 18:13, 29 November 2011
--D. Thiebaut 12:41, 29 November 2011 (EST)
This is an A/E type of homework. You have several problems to solve. You either get an A or an E on each one. What is important here is Python, not documentation or robustness (this is an exception to the rule!--pun intended!). You have to solve different problems and make your program output the correct answer. Correct answers get A, incorrect ones get E. I will not read the code closely and take point for lack of documentation, and I will not try to make your program crash to test its robustness.
The main goal for this particular assignment is for you to use classes and objects and make them work.
This assignment is due Tuesday evening, Dec. 6, at midnight.
Contents
Problem 1
- Modify the car class we saw in class (some code available on the class Web page), and make the class contain
- a rectangle for the body,
- a rectangle for the cab part,
- a rectangle (or rectangles) for the window (or windows),
- a Text caption in the middle of the body (s.a. "Taxi" ),
- and a move() method, so that we can make the car move out of the screen with this loop:
for i in range( 500 ): car.move( 2, 0 );
- (we assume that car is an object instantiated from the class Car.)
- Make your program implement this loop so that we can see the car move out of the graphic window.
Submission
- Store your program in a file called hw10a.py and submit it this way:
rsubmit hw10 hw10a.py
- if you are working on beowulf or use the http://cs.smith.edu/~111a/submit10.htm submit form.
Problem 2
- Play with the program below:
from graphics import *
class Ball:
def __init__(self, c, r ):
self.c = Circle( c, r )
self.dx = 0
self.dy = 0
def draw( self, win ):
self.c.draw( win )
def setFill( self, col ):
self.c.setFill( col )
def setDirection( self, dx, dy ):
self.dx = dx
self.dy = dy
def move( self ):
self.c.move( self.dx, self.dy )
def main():
width = 800
height = 600
win = GraphWin( "111a-xx HW10", width, height )
b1 = Ball( Point( width/4, height/2 ), 10 )
b1.setFill( "blue" )
b1.setDirection( 1, 2 )
b1.draw( win )
b2 = Ball( Point( width/4, height/2 ), 10 )
b2.setFill( "green" )
b2.setDirection( 2, 1 )
b2.draw( win )
while True:
b1.move()
b2.move()
if win.checkMouse() != None:
break
win.close()
main()
- This code is not documented, and for this homework documentation is not required.
- Note how each ball remembers its direction of movement in the two member variables self.dx and self.dy.
Assignment
- Add a new method to the Ball class called changeDirIfHittingWall(). This method changes the sign of self.dx or of self.dy when the ball hits a vertical or horizontal wall (the boundaries of the window). For example, when the ball hits a vertical wall, then the method will change self.dx to be -self.dx.
- If your method is written correctly, the main function below will see the balls bouncing off all the windows borders in a natural fashion, in a way similar to what we have done many times before.
def main():
width = 800
height = 600
win = GraphWin( "111a-xx HW10", width, height )
b1 = Ball( Point( width/4, height/2 ), 10 )
b1.setFill( "blue" )
b1.setDirection( 1, 2 )
b1.draw( win )
b2 = Ball( Point( width/4, height/2 ), 10 )
b2.setFill( "green" )
b2.setDirection( 2, 1 )
b2.draw( win )
while True:
b1.move()
b2.move()
if win.checkMouse() != None:
break
b1.changeDirIfHittingWall( width, height )
b2.changeDirIfHittingWall( width, height )
win.close()
Additional Information
- the balls must bounce off all four borders of the window.
- the balls do not have to bounce off each other.
Submission
- Call your program hw10b.py and submit it as indicated in Problem 1 above.
Problem 3
- And you thought we were done with the presidents!...
- Play with the code below:
presidents = \
"""Presidency ,President ,Wikipedia Entry,Took office ,Left office ,Party ,Portrait,Thumbnail,Home State
1,George Washington,http://en.wikipedia.org/wiki/George_Washington,30/04/1789,4/03/1797,Independent ,GeorgeWashington.jpg,thmb_GeorgeWashington.jpg,Virginia
2,John Adams,http://en.wikipedia.org/wiki/John_Adams,4/03/1797,4/03/1801,Federalist ,JohnAdams.jpg,thmb_JohnAdams.jpg,Massachusetts
3,Thomas Jefferson,http://en.wikipedia.org/wiki/Thomas_Jefferson,4/03/1801,4/03/1809,Democratic-Republican ,Thomasjefferson.gif,thmb_Thomasjefferson.gif,Virginia
4,James Madison,http://en.wikipedia.org/wiki/James_Madison,4/03/1809,4/03/1817,Democratic-Republican ,JamesMadison.gif,thmb_JamesMadison.gif,Virginia
5,James Monroe,http://en.wikipedia.org/wiki/James_Monroe,4/03/1817,4/03/1825,Democratic-Republican ,JamesMonroe.gif,thmb_JamesMonroe.gif,Virginia
6,John Quincy Adams,http://en.wikipedia.org/wiki/John_Quincy_Adams,4/03/1825,4/03/1829,Democratic-Republican/National Republican ,JohnQuincyAdams.gif,thmb_JohnQuincyAdams.gif,Massachusetts
7,Andrew Jackson,http://en.wikipedia.org/wiki/Andrew_Jackson,4/03/1829,4/03/1837,Democratic ,Andrew_jackson_head.gif,thmb_Andrew_jackson_head.gif,Tennessee
8,Martin Van Buren,http://en.wikipedia.org/wiki/Martin_Van_Buren,4/03/1837,4/03/1841,Democratic ,MartinVanBuren.gif,thmb_MartinVanBuren.gif,New York
9,William Henry Harrison,http://en.wikipedia.org/wiki/William_Henry_Harrison,4/03/1841,4/04/1841,Whig,WilliamHenryHarrison.gif,thmb_WilliamHenryHarrison.gif,Ohio
10,John Tyler,http://en.wikipedia.org/wiki/John_Tyler,4/04/1841,4/03/1845,Whig,JohnTyler.jpg,thmb_JohnTyler.jpg,Virginia
11,James K. Polk,http://en.wikipedia.org/wiki/James_K._Polk,4/03/1845,4/03/1849,Democratic ,JamesKPolk.gif,thmb_JamesKPolk.gif,Tennessee
12,Zachary Taylor,http://en.wikipedia.org/wiki/Zachary_Taylor,4/03/1849,9/07/1850,Whig,ZacharyTaylor.jpg,thmb_ZacharyTaylor.jpg,Louisiana
13,Millard Fillmore,http://en.wikipedia.org/wiki/Millard_Fillmore,9/07/1850,4/03/1853,Whig,MillardFillmore.png,thmb_MillardFillmore.png,New York
14,Franklin Pierce,http://en.wikipedia.org/wiki/Franklin_Pierce,4/03/1853,4/03/1857,Democratic ,FranklinPierce.gif,thmb_FranklinPierce.gif,New Hampshire
15,James Buchanan,http://en.wikipedia.org/wiki/James_Buchanan,4/03/1857,4/03/1861,Democratic ,JamesBuchanan.gif,thmb_JamesBuchanan.gif,Pennsylvania
16,Abraham Lincoln,http://en.wikipedia.org/wiki/Abraham_Lincoln,4/03/1861,15/04/1865,Republican/National Union,AbrahamLincoln.jpg,thmb_AbrahamLincoln.jpg,Illinois
17,Andrew Johnson,http://en.wikipedia.org/wiki/Andrew_Johnson,15/04/1865,4/03/1869,Democratic/National Union,AndrewJohnson.gif,thmb_AndrewJohnson.gif,Tennessee
18,Ulysses S. Grant,http://en.wikipedia.org/wiki/Ulysses_S._Grant,4/03/1869,4/03/1877,Republican ,UlyssesSGrant.gif,thmb_UlyssesSGrant.gif,Ohio
19,Rutherford B. Hayes,http://en.wikipedia.org/wiki/Rutherford_B._Hayes,4/03/1877,4/03/1881,Republican ,RutherfordBHayes.png,thmb_RutherfordBHayes.png,Ohio
20,James A. Garfield,http://en.wikipedia.org/wiki/James_A._Garfield,4/03/1881,19/09/1881,Republican ,James_Garfield.jpg,thmb_James_Garfield.jpg,Ohio
21,Chester A. Arthur,http://en.wikipedia.org/wiki/Chester_A._Arthur,19/09/1881,4/03/1885,Republican ,ChesterAArthur.gif,thmb_ChesterAArthur.gif,New York
22,Grover Cleveland,http://en.wikipedia.org/wiki/Grover_Cleveland,4/03/1885,4/03/1889,Democratic ,Grover_Cleveland_2.jpg,thmb_Grover_Cleveland_2.jpg,New York
23,Benjamin Harrison,http://en.wikipedia.org/wiki/Benjamin_Harrison,4/03/1889,4/03/1893,Republican ,BenjaminHarrison.gif,thmb_BenjaminHarrison.gif,Indiana
24,Grover Cleveland,http://en.wikipedia.org/wiki/Grover_Cleveland,4/03/1893,4/03/1897,Democratic ,Grover_Cleveland.jpg,thmb_Grover_Cleveland.jpg,New York
25,William McKinley,http://en.wikipedia.org/wiki/William_McKinley,4/03/1897,14/9/1901,Republican ,WilliamMcKinley.gif,thmb_WilliamMcKinley.gif,Ohio
26,Theodore Roosevelt,http://en.wikipedia.org/wiki/Theodore_Roosevelt,14/9/1901,4/3/1909,Republican ,TheodoreRoosevelt.jpg,thmb_TheodoreRoosevelt.jpg,New York
27,William Howard Taft,http://en.wikipedia.org/wiki/William_Howard_Taft,4/3/1909,4/03/1913,Republican ,WilliamHowardTaft.jpg,thmb_WilliamHowardTaft.jpg,Ohio
28,Woodrow Wilson,http://en.wikipedia.org/wiki/Woodrow_Wilson,4/03/1913,4/03/1921,Democratic ,WoodrowWilson.gif,thmb_WoodrowWilson.gif,New Jersey
29,Warren G. Harding,http://en.wikipedia.org/wiki/Warren_G._Harding,4/03/1921,2/8/1923,Republican ,WarrenGHarding.gif,thmb_WarrenGHarding.gif,Ohio
30,Calvin Coolidge,http://en.wikipedia.org/wiki/Calvin_Coolidge,2/8/1923,4/03/1929,Republican ,CoolidgeWHPortrait.gif,thmb_CoolidgeWHPortrait.gif,Massachusetts
31,Herbert Hoover,http://en.wikipedia.org/wiki/Herbert_Hoover,4/03/1929,4/03/1933,Republican ,HerbertHover.gif,thmb_HerbertHover.gif,Iowa
32,Franklin D. Roosevelt,http://en.wikipedia.org/wiki/Franklin_D._Roosevelt,4/03/1933,12/4/1945,Democratic,FranklinDRoosevelt.gif,thmb_FranklinDRoosevelt.gif,New York
33,Harry S. Truman,http://en.wikipedia.org/wiki/Harry_S._Truman,12/4/1945,20/01/1953,Democratic,HarryTruman.jpg,thmb_HarryTruman.jpg,Missouri
34,Dwight D. Eisenhower,http://en.wikipedia.org/wiki/Dwight_D._Eisenhower,20/01/1953,20/01/1961,Republican ,Dwight_D_Eisenhower.jpg,thmb_Dwight_D_Eisenhower.jpg,Texas
35,John F. Kennedy,http://en.wikipedia.org/wiki/John_F._Kennedy,20/01/1961,22/11/1963,Democratic,John_F_Kennedy.jpg,thmb_John_F_Kennedy.jpg,Massachusetts
36,Lyndon B. Johnson,http://en.wikipedia.org/wiki/Lyndon_B._Johnson,22/11/1963,20/1/1969,Democratic,Lyndon_B_Johnson.gif,thmb_Lyndon_B_Johnson.gif,Texas
37,Richard Nixon,http://en.wikipedia.org/wiki/Richard_Nixon,20/1/1969,9/8/1974,Republican,RichardNixon.gif,thmb_RichardNixon.gif,California
38,Gerald Ford,http://en.wikipedia.org/wiki/Gerald_Ford,9/8/1974,20/01/1977,Republican,Gerald_R_Ford.jpg,thmb_Gerald_R_Ford.jpg,Michigan
39,Jimmy Carter,http://en.wikipedia.org/wiki/Jimmy_Carter,20/01/1977,20/01/1981,Democratic ,James_E_Carter.gif,thmb_James_E_Carter.gif,Georgia
40,Ronald Reagan,http://en.wikipedia.org/wiki/Ronald_Reagan,20/01/1981,20/01/1989,Republican ,ReaganWH.jpg,thmb_ReaganWH.jpg,California
41,George H. W. Bush,http://en.wikipedia.org/wiki/George_H._W._Bush,20/01/1989,20/01/1993,Republican ,George_H_W_Bush.gif,thmb_George_H_W_Bush.gif,Texas
42,Bill Clinton,http://en.wikipedia.org/wiki/Bill_Clinton,20/01/1993,20/01/2001,Democratic ,Clinton.jpg,thmb_Clinton.jpg,Arkansas
43,George W. Bush,http://en.wikipedia.org/wiki/George_W._Bush,20/01/2001,20/01/2009,Republican ,George_W_Bush.jpg,thmb_George_W_Bush.jpg,Texas
44,Barack Obama, http://en.wikipedia.org/wiki/Barack_Obama,20/01/2009,Incumbent , Democratic ,Barack_Obama.jpg,thmb_Barack_Obama.jpg,Illinois"""
class President:
""" A class for one president. Holds all the info relative to a president as strings"""
def __init__( self, n, name, url, dateIn, dateOut, party, pic, thumb, state ):
self.n = n
self.name = name
self.url = url
self.dateIn = dateIn
self.dateOut = dateOut
self.party = party
self.pic = pic
self.thumb = thumb
self.state = state
def isDemocrat( self ):
return self.party.lower().find( "democ" ) != -1
def isRepublican( self ):
return self.party.lower().find( "republi" ) != -1
def is3rdParty( self ):
return not self.isDemocrat() and not self.isRepublican()
def toString( self ):
party = ""
if self.isDemocrat(): party = "D"
if self.isRepublican(): party += "R"
if self.is3rdParty(): party = "Other"
return "%s: %30s(%s) %s-%s from %s" % \
( self.n, self.name, party, self.dateIn, self.dateOut, self.state )
def createListOfPres( text ):
"""parses the text containing the CSV list of presidents and returns a list of
president objects, or an empty list if nothing could be read"""
try:
lines = text.split( '\n' )[1:]
except (IndexError ):
return []
prez = []
for line in lines:
try:
n, name, url, dateIn, dateOut, party, pic, thumb, state = line.split( ',' )
except (ValueError,NameError):
continue
# create president object and add it to the list prez
prez.append( President( n, name, url, dateIn, dateOut, party, pic, thumb, state ) )
# return the list of president objects
return prez
def main():
# get a list of objects, each one a president
prez = createListOfPres( presidents )
# print each president without url or image info.
for p in prez:
print( p.toString() )
main()
Your assignment
Part 1
- For this part you cannot modify the President class.
- Make the main program output the number of democratic presidents, the number of republican presidents, and the number of "other" party presidents.
- You can only modify the main() function.
- Whatever you do, you cannot use the string presidents again, once it has been processed by createListOfPres().
Part 2
- For this part you can add new methods to the President class.
- You cannot use the string presidents once createListOfPres() has parsed it.
- Make your program prompt the user for a year, and output the president or presidents who was/were on active duty that year.
- It is fine (no penalty) if your program does not output Obama for 2011, but it is nice if it does!
Submission
- Store your program in a file called hw10c.py and submit it as illustrated in Problem 1 above.
Problem 4
Your assignment
- My cat ate my program! Yes, she did! I had a nicely written (though not documented) program, was ready to show it to you, but my cat ate part of it.
- The good part is: I kept a copy of the program's output when it was still in its complete state:
Cheetah 70.0 mph
Pronghorn Antelope 61.0 mph
Wildebeest 50.0 mph
Lion 50.0 mph
Thomson's Gazelle 50.0 mph
Quarter Horse 47.5 mph
Elk 45.0 mph
Cape Hunting Dog 45.0 mph
Coyote 43.0 mph
Gray Fox 42.0 mph
Hyena 40.0 mph
Zebra 40.0 mph
Mongolian Wild Ass 40.0 mph
Greyhound 39.4 mph
Whippet 35.5 mph
Rabbit (domestic) 35.0 mph
Mule Deer 35.0 mph
Jackal 35.0 mph
Reindeer 32.0 mph
Giraffe 32.0 mph
White-Tailed Deer 30.0 mph
Warthog 30.0 mph
Grizzly Bear 30.0 mph
Cat (domestic) 30.0 mph
Human 27.9 mph
Elephant 25.0 mph
Black Mamba Snake 20.0 mph
Six-Lined Racerunner 18.0 mph
Wild Turkey 15.0 mph
Squirrel 12.0 mph
Pig (domestic) 11.0 mph
Chicken 9.0 mph
Spider (Tegenaria atrica) 1.2 mph
Giant Tortoise 0.2 mph
Three-Toed Sloth 0.1 mph
Garden Snail 0.0 mph
Fastest animal: Cheetah
Slowest animal: Garden Snail
Closest to 0 miles/hour: Garden Snail 0.03 mph
Closest to 3 miles/hour: Spider (Tegenaria atrica) 1.17 mph
Closest to 6 miles/hour: Chicken 9 mph
Closest to 9 miles/hour: Chicken 9 mph
Closest to 12 miles/hour: Squirrel 12 mph
Closest to 15 miles/hour: Wild Turkey 15 mph
Closest to 18 miles/hour: Six-Lined Racerunner 18 mph
Closest to 21 miles/hour: Black Mamba Snake 20 mph
Closest to 24 miles/hour: Elephant 25 mph
Closest to 27 miles/hour: Human 27.89 mph
Closest to 30 miles/hour: Cat (domestic) 30 mph
Closest to 33 miles/hour: Giraffe 32 mph
Closest to 36 miles/hour: Whippet 35.5 mph
Closest to 39 miles/hour: Greyhound 39.35 mph
Closest to 42 miles/hour: Gray Fox 42 mph
Closest to 45 miles/hour: Cape Hunting Dog 45 mph
Closest to 48 miles/hour: Quarter Horse 47.5 mph
- Unfortunately all I can reassemble from the pieces of paper I could get back from the tiger's claws is this:
animalSpeed = """Cheetah 70
Pronghorn Antelope 61
Wildebeest 50
Lion 50
Thomson's Gazelle 50
Spider (Tegenaria atrica) 1.17
Giant Tortoise 0.17
Three-Toed Sloth 0.15
Garden Snail 0.03"""
class AnimalList:
def __init__( self ):
self.List = []
def append( self, animal, speed):
self.List.append( [ ] )
def get( self, index ):
if 0 <= index < len( self.List ):
speed, animal = self.List[ index ]
return animal, speed
return None, None
def size( self ):
return len( self.List )
def sort( self ):
...
def reverse( self ):
self.List.reverse()
def getFastest( self ):
self.sort()
if len( self.List )> 0:
speed, animal = self.List[ -1 ]
return animal, speed
return None, None
def topN( self, n ):
return self.List[-n: ]
def closestInSpeedTo( self, targetSpeed ):
if len( self.List )==0:
return None, None
closestSpeed, closestAnimal = self.List[0]
for speed, animal in self.List:
if abs( targetSpeed - closestSpeed ) > abs( targetSpeed - speed ):
closestSpeed = speed
closestAnimal = animal
return closestAnimal, closestSpeed
def main():
animals = AnimalList()
for line in animalSpeed.split( '\n' ):
words = line.split()
speed =
animal =
animals.append( animal, speed )
for i in range( animals.size() ):
animal, speed = animals.get( i )
print( "%30s %10.1f mph" % (animal, speed ) )
animal, speed = animals.getSlowest()
print( "Slowest animal: ", animal )
for target in range( 0, 50, 3 ):
animal, speed = animals.closestInSpeedTo( target )
print( "Closest to", target," miles/hour:", animal, speed, "mph" )
main()
- Figure out what code is missing so that the output of your program matches exactly the output shown above.
Submission
- call your program hw10d.py and submit it as illustrated in Problem 1 above.