Computer Science 385
Design and Analysis of Algorithms
Spring 2018, Siena College
You may work alone or in a group of 2 or 3 on this assignment, which consists of an extension of your previous empirical analysis study to include more of the sorting algorithms we have studied this semester.
All GitHub repositories must be created with all group members having write access and all group member names specified in the README.md file by 4:00 PM, Monday, April 9, 2018. This applies to those who choose to work alone as well!
Getting Set Up
You will receive an email with the link to follow to set up your GitHub repository, which will be named ps6-yourgitname, for this problem set. One member of the group should follow the link to set up the repository on GitHub, then that person should email the instructor with the other group members' GitHub usernames so they can be granted access. This will allow all members of the group to clone the repository and commit and push changes to the origin on GitHub.
Submitting
Your submission requires that all required code and other deliverables are committed and pushed to the master for your repository's origin on GitHub. That's it! If you see everything you intend to submit when you visit your repository's page on GitHub, you're set.
Extended Empirical Analysis of Sorting Algorithms
Your task, worth a total of 50 points, is to extend your previous empirical study of sorting algorithms.
Grade Improvement Opportunity
If you include your previous or updated results from the earlier empirical study here, your grade for this problem set can replace your earlier grade. That problem set had the lowest average grade to date, so this can really help many of you. Be sure to take into account the comments from that earlier problem set's grading sheet when preparing this submission whether or not you are including the earlier sort algorithms here.
Deliverables
A typical submission will include the program used to generate the results (source code only, not extra files like .class or package.bluej files), a PDF document that contains the formal writeup, and any spreadsheets or other files that include the raw data.
The formal writeup should have a section that includes a brief introduction to the task, including test environment information. There should then be a section for each algorithm that describes specifics of that algorithm, the theoretical expectations (including best/average/worst cases, where applicable), a summary of your timings and counts in tabular format, graphs illustrating these results, followed by more text that analyzes the results, comparing with the theoretical expectations. A brief conclusion section should summarize the study's results.