CSCI 255 Fall 2022
Introduction to Algorithms and Discrete Structures
Archived Class
Charles Cusack
Computer Science
Hope College
Main
Schedule
Grading
Gradebook
Homework

Policies
Advice
College
    Policies

Notes
Programs
Tutorials

CSCI 125
CSCI 255
Others

Admin

Homework 17

General Comments

  • Most problems are found in one of the following:
    1. AIDMA: An Active Introduction to Discrete Mathematics and Algorithms
    2. IDAA: Introduction to the Design and Analysis of Algorithms
  • For full credit, provide context for each problem, show all calculations, and justify all answers by providing enough comments to explain your reasoning.
  • You will lose a significant amount of credit if you do not provide context, calculations, and justifications for a problem.
  • Numbers and/or algebra by themselves are not enough. A correct answer with no justification will be worth no more than half credit, and sometimes much less than that.
  • Precision is very important. You cannot skip steps, make guesses, or use flawed logic. Any of these things can lead to incorrect answers.
  • Homework assignments must be very neatly written or typeset (e.g. using Word or OpenOffice).
  • Remember that you can get up to 50% credit on a problem if you get significant outside assistance. Thus, if you are totally stuck on a problem it might be worth getting help. However, you must indicate any assistance/collaboration (See the Homework Assistance section on the Policies page). Failure to do so could result in a failing grade for the course! Note that getting help from the Help Center or me does not count as significant outside assistance, but talking with your classmates or searching on the Internet does!
  • If a problem asks for an algorithm, you should give the most efficient algorithm you can find to ensure full credit. You should also specify the complexity of the algorithm with justification, whether or not the problem asks for it.

Details

  1. IDAA 6.1 #2 (page 205) (10 points)
    Note: Read carefully. The arrays have different sizes. Keep in mind that the goal for part b is to be as efficient as possible. Make sure your algorithm description is clear and unambiguous (paragraph form is probably better for this one). Don't forget to analyze your algorithms!
  2. IDAA 6.3 #7a (not b) (page 226) (10 points)
    Show enough work so it is clear how the final tree was obtained. (In other words, show the intermediate trees.)
  3. IDAA 6.4 #6 (page 233) (15 points)
    Give your solution in a nicely formatted table. Also, in case it isn't clear, the three operations are insert, deleteMax, and getMax.
  4. This problem: (10 points)
    Compute
    111329 mod 100
    by hand (That is, you are not allowed to use a calculator, computer, abacus, or any other computational device besides your brain) using one of the binary exponentiation algorithms. Show all of your work. You are permitted to verify that your answer is correct with the use of a computer or calculator. In case it is not clear, you may do all of your intermediate computations modulo 100 and you will still get the same answer. For instance, 11*11=121=21 mod 100, so you can use 21 instead of 121 in the next calculation.