Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Problem 1

Modify the statistics program from this chapter so that client programs have more flexibility in computing the mean and/or standard deviation. Specifically, redesign the library to have the following functions: mean(nums) Returns the mean of numbers in nums. stdDev(nums) Returns the standard deviation of nums. meanStdDev(nums) Returns both the mean and standard deviation of nums.

Problem 2

Extend the gpasort program so that it allows the user to sort a file of students based on GPA, name, or credits. Your program should prompt for the input file, the field to sort on, and the output file.

Problem 5

Most languages do not have the flexible built-in list (array) operations that Python has. Write an algorithm for each of the following Python operations and test your algorithm by writing it up in a suitable function. For example, as a function, reverse(myList) should do the same as myList.reverse(). Obviously, you are not allowed to use the corresponding Python method to implement your function. a) count(mylist, x) (like myList.count(x)) b) isin(myList, x) (like x in myList)) c) index(myList, x) (like myList. index \((x)\) ) d) reverse(myList) (like myList.reverse()) e) sort(mylist) (like myList.sort())

Problem 6

Write and test a function shuffle(myList) that scrambles a list into a random order, like shuffling a deck of cards.

Problem 7

Write and test a function innerProd \((x, y)\) that computes the inner product of two (same length) lists. The inner product of \(x\) and \(y\) is computed as: \\[\sum_{i=0}^{n-1} x_{i} y_{i}\\]

Problem 8

Write and test a function removeDuplicates(somelist) that removes duplicate values from a list.

Problem 10

The Sieve of Eratosthenes is an elegant algorithm for finding all of the prime numbers up to some limit \(n\). The basic idea is to first create a list of numbers from 2 to \(n\). The first number is removed from the list, and announced as a prime number, and all multiples of this number up to \(n\) are removed from the list. This process continues until the list is empty. For example, if we wished to find all the primes up to \(10,\) the list would originally contain \(2,3,4,5,6,7,8,9,10 .\) The 2 is removed and announced to be prime. Then \(4,6,8,\) and 10 are removed, since they are multiples of 2. That leaves 3, 5, 7, 9. Repeating the process. 3 is announced as prime and removed, and 9 is removed because it is a multiple of 3. That leaves 5 and 7. The algorithm continues by announcing that 5 is prime and removing it from the list. Finally, 7 is announced and removed, and we're done. Write a program that prompts a user for \(n\) and then uses the sieve algorithm to find all the primes less than or equal to \(n\).

Problem 11

Write an automated censor program that reads in the text from a file and creates a new file where all of the four-letter words have been replaced by "****". You can ignore punctuation, and you may assume that no words in the file are split across multiple lines.

Problem 17

In graphics applications, it is often useful to group separate pieces of a drawing together into a single object. For example, a face might be drawn from individual shapes, but then positioned as a whole group. Create a new class GraphicsGroup that can be used for this purpose. A GraphicsGroup will manage a list of graphics objects and have the following methods: init_(self, anchor) anchor is a Point. Creates an empty group with the given anchor point. getAnchor(self) Returns a clone of the anchor point. addObject(self, gObject) g0bject is a graphics object. Adds gObject to the group. move (self, \(d x, d y\) ) Moves all of the objects in the group (including the anchor point). draw(self, win) Draws all the objects in the group into win. The anchor point is not drawn. undraw(self) Undraws all the objects in the group. Use your new class to write a program that draws some simple picture with multiple components and moves it to wherever the user clicks.

Problem 19

Create and test a Set class to represent a classical set. Your sets should support the following methods: Set (elements) Creates a set (elements is the initial list of items in the set \()\) addElement \((x)\) Adds \(x\) to the set. deleteElement \((\mathrm{x})\) Removes \(\mathrm{x}\) from the set, if present. If \(\mathrm{x}\) is not in the set, the set is left unchanged. member \((\mathrm{x})\) Returns true if \(\mathrm{x}\) is in the set and false otherwise. intersection(set2) Returns a new set containing just those elements that are common to this set and set2. union(set2) Returns a new set containing all of elements that are in this set, set2, or both. subtract (set2) Returns a new set containing all the elements of this set that are not in set2. By the way, sets are so useful that Python actually has a built-in set datatype. While you may want to investigate Python's set, you should not use it here. The point of this exercise is to help you develop your skills in algorithm development using lists and dictionaries.

Access millions of textbook solutions in one place

  • Access over 3 million high quality textbook solutions
  • Access our popular flashcard, quiz, mock-exam and notes features
  • Access our smart AI features to upgrade your learning
Get Vaia Premium now
Access millions of textbook solutions in one place

Recommended explanations on Computer Science Textbooks