python, computer science homework help

Anonymous
account_balance_wallet $20

Question Description

please follow the instruction

Unformatted Attachment Preview

CS 112, Lab 8 – Exercise – Functions Due: Monday, March 27th, 11:59pm Files: • • You should download tester8L.py from Piazza for testing. Grading is based on the fraction of passing tests. You can run it like this: python3 tester8L.py gmason76_230_L8.py • If you only want to test some functions, you can run it like this: (only testing extract_negatives) python3 tester8L.py gmason76_230_L8.py extract_negatives As this is an Exercise, you can read any and all materials, ask us questions, talk with other students, and learn however you best learn in order to solve the task. Just create your own solution from those experiences, and turn in your work. We can define functions to name a block of code, and then feed it inputs and get an output. Functions also allow us to give default values for parameters, which is useful but needs special attention. We will write functions that are more than just side-effect-free input-output factories. Notes • • • • You cannot import any modules. Don't call input() or print() anywhere. We need you to figure out the "signature" (top line) of some functions, so we don't explicitly show you the parameters lists for those functions. Part of the goal is learning how to choose when to use default parameters, and what default values to use. You're also learning when to modify the original or not; test cases should target this fact. Turning It In Add a comment at the top of the file that indicates your name, userID, G#, lab section, a description of your collaboration partners, as well as any other details you feel like sharing. Please also mention what was most helpful for you. Once you are done, run the testing script once more to make sure you didn't break things while adding these comments. If all is well, go ahead and turn in just your one .py file you've been working on, named with our usual convention (see above), over on BlackBoard to the correct lab assignment. Please don't turn in the tester file or any other extra files, as it will just slow us down. Grading Rubric Pass shared test cases 4x25 (zero points for hard-coding) ----------------------------------TOTAL: 100 Tasks Implement each of the following functions. • def simple_pig_latin(input, sep=" ", end="."): Accept a string input, which might include multiple words separated by a separator sep and perform the following steps: o Find the list of “words” (Note: “words” are just “zero or more characters separated by a symbol”. So, depending on the separator ' ' or 'a..b' could be a “word”.). o Inspect every “word” and apply the following conversions: § if the word starts with a non-letter or contains no characters, do nothing to it § if the word starts with a vowel, add 'way' to the end § if the word starts with a consonant, place the first letter at the end and add 'ay' o Reassemble the words back into one string and return it, making sure a single sep is padded between any two neighboring words and the final string ends with end. o Assume: the input does not have any capital letters o Go ahead and use string methods like .join(), .split() Examples: o simple_pig_latin("i like this") → 'iway ikelay histay.' # default sep(space) and end(dot) o simple_pig_latin("i like this", sep='.') → 'i like thisway.' # separator is dot, so whole thing is a single “word” o simple_pig_latin("i-like-this","-") → 'iway-ikelay-histay.' # sep is '-' and default end(dot) o simple_pig_latin("i.like.this",sep='.',end='!') → 'iway.ikelay.histay!' # sep is '.' and end is '!' o simple_pig_latin(".") → '..' # only word is '.', so do nothing to it and add a '.' to the end • def replace(xs,old,new,limit=None): Given a list xs, replace occurrences of old value with new value. An optional fourth argument limit is an integer states the maximum number of replacements allowed. You should only replace up to the first limit occurrences of old and leave the rest unchanged. When limit==None, there's truly no limit (and we replace all occurrences of old). Negative or zero limit: no replacement. o Assume: xs is a list; xs could be empty. o Return None, because the replacement happened in-place. Examples: o o o >>> xs = [1,2,1,3,1,4,1,5,1] >>> replace(xs,1,-1) >>> xs [-1, 2, -1, 3, -1, 4, -1, 5, -1] #returns None #replace all >>> xs = [1,2,1,3,1,4,1,5,1] >>> replace(xs,1,-1,2) >>> xs [-1, 2, -1, 3, 1, 4, 1, 5, 1] #replace only the first 2 occurrences >>> >>> >>> [1, #replace none xs = [1,2,1,3,1,4,1,5,1] replace(xs,1,-1,-100) xs 2, 1, 3, 1, 4, 1, 5, 1] • extract_negatives: The first argument, xs, contains integers. We will be removing any negative integers we find in xs, and appending them to the second argument, new_home. A reference to the list that received negatives must be returned. When no second argument is given, a list of all the extracted negatives should be created and returned. o Figuring out the signature of this function is part of the task. Careful: What default value do you want to use for new_home? What happens when we call the function multiple times in the same coding session? (try it out) o Go ahead and use methods like .insert(), .pop(), .append() o You might need to iterate and update the list at the same time. Hint: if you need to traverse a list from front to back, but you don't always want to go to the next index location, while loops can be very useful – we get to control when (which iteration) to step forward. Examples: o >>> xs = [1,-22,3,-44,-5,6,7] >>> extract_negatives(xs) [-22, -44, -5] #return a list of negatives >>> xs [1, 3, 6, 7] #remove negatives from xs o >>> xs = [1,-22,3,-44,-5,6,7] >>> negatives = [-3, -1] >>> extract_negatives(xs, negatives) [-3, -1, -22,-44,-5] >>> negatives [-3, -1, -22,-44,-5] #new negatives appended to the list >>> xs [1, 3, 6, 7] ...
Purchase answer to see full attachment

Tutor Answer

Teacherg
School: UCLA

Hello check the output as required...

flag Report DMCA
Review

Anonymous
Excellent job

Similar Questions
Related Tags

Brown University





1271 Tutors

California Institute of Technology




2131 Tutors

Carnegie Mellon University




982 Tutors

Columbia University





1256 Tutors

Dartmouth University





2113 Tutors

Emory University





2279 Tutors

Harvard University





599 Tutors

Massachusetts Institute of Technology



2319 Tutors

New York University





1645 Tutors

Notre Dam University





1911 Tutors

Oklahoma University





2122 Tutors

Pennsylvania State University





932 Tutors

Princeton University





1211 Tutors

Stanford University





983 Tutors

University of California





1282 Tutors

Oxford University





123 Tutors

Yale University





2325 Tutors