SYLLABUS HANDOUT for Spring, 2004–2005 Data Structures and Algorithms CPT 240 2A Th • 6:00 p.m.–9:35 p.m. Alan R. Reinarz WELCOME TO METROPOLITAN COMMUNITY COLLEGE Metro Community College Page 1 of 8 Revised: May-03 SYLLABUS METROPOLITAN COMMUNITY COLLEGE SECTION I: THE CLASS AND THE INSTRUCTOR COURSE SECTION AND TITLE: CPT 240 2A Data Structures and Algorithms ACADEMIC YEAR/QUARTER: Spring, 2004–2005 INSTRUCTOR’S NAME: Alan R. Reinarz LOCATION OF CLASS: EVC 131 LOCATION OF LABS: EVC 157, or CT lab at any campus or center METHODS OF CONTACTING INSTRUCTOR: areinarz@mccneb.edu http://cot.mccneb.edu/areinarz METRO OFFICES HOURS* LOCATION PHONE FAX M/T: 10:00a-11:00a T: 4:00p-5:00p W: 2:00p-3:00p F: 1:00p-2:00p SOC MAH 300 738-4089 738-4553 EVC 156 289-1364 289-1405 EVC 125 289-1451 289-1222 Th: 4:00p-5:00p *Stated office hours may need to be changed due to special circumstances or events. If the student wishes to meet with the instructor at a time other than scheduled office hours, the student should make an appointment with the instructor. Home phone: (402) 556-3071 IMPORTANT DATES: (This section can be here, or at the end of the syllabus under Section IV) DATE CLASS BEGINS: DATE CLASS ENDS: LAST DATE TO DROP CLASS: DATES CLASS DOES NOT MEET: March 10, 2005 May 19, 2005 May 4, 2005 none SECTION II: THE COURSE COURSE DESCRIPTION: This course builds upon the foundation provided by the CPT 123-125 sequence to introduce the fundamental concepts of data structures and the algorithms that proceed from them. Topics include recursion, the underlying philosophy of object-oriented programming, fundamental data structures (including stacks, queues, linked lists, hash tables, trees and graphs), the basics of algorithmic analysis, and an introduction to the principles of language translation. The course also provides broad coverage of the C programming language, where it differs from C++. Metro Community College Page 2 of 8 Revised: May-03 COURSE PREREQUISITES: CPT 125: C++ Programming II COURSE OBJECTIVES: Upon completion of this course, the student will be able to: 1. Understand storage classes, their scope and persistence... 2. Understand the C Preprocessor, the C Library and the ANSI-C Standard. 3. Understand and be able to use Structures, Unions, and Enumerations. 4. Understand and be able to use in a C program, typedefs and Complex Declarations. 5. Understand linked and double linked lists and be able to use them in a C program. 6. Understand and be able to write code to generate Queues, Circular Queues and Stacks. 7. Understand the basic concept of modular programming and be able to develop programs from modules. 8. Be familiar with the capabilities of Make files and be able to create a simple make file to assist in the generation of an executable program. REQUIRED/SUPPLEMENTAL MATERIALS: C How To Program Edition: 2003—4th [2001-3rd [1997-2nd]] Author: Deitel & Deitel Publisher: Prentice Hall Title: C++ Programming: Program Design Including Data Structures Edition: 2004—2nd Author: D. S. Malik Publisher:: Course Technology Materials: Two 3.5" disks Title: SECTION III: STUDENT RESPONSIBILITIES METHODS OF LEARNING: The student will have specific assignments to read and master. These assignments are indicated in the course schedule and/or outlined by the instructor. The student should have read the material prior to class meeting date. This course requires students to work an average of 1.5 hours per week in hands-on, lab activity. Students are responsible for completing all lab work outside of the classroom. A “personal” version of the software used in this class is available to the student at additional cost. Metro provides the necessary software in this classroom and in all “Computer and Office Technology” computer labs ATTENDANCE STATEMENT: The course will be covered partially by assigned portions of the text and may be presented in a sequence different from the text. Material will also be covered that is not in the text. Attendance is necessary to understand the course material. Each student is expected to recognize the importance of class attendance and promptness. CHRONIC TARDINESS AND ABSENCES MAY RESULT IN A REDUCTION IN THE FINAL GRADE BY 10%. Excessive absences or unsatisfactory progress will subject the student to administrative withdrawal from the course. If a student should miss a class for any reason, he/she is expected to cover the material he/she missed on his/her own. All work must be made up to the satisfaction of the instructor. Metro Community College Page 3 of 8 Revised: May-03 RETAINING COPIES OF SUBMITTED WORK: On very rare occasion, the instructor has been unable to find any record of work that a student claims to have submitted. There may be several reasons this has occurred, including loss or theft of the work before it gets to the instructor, or oversight on the part of the student or instructor. The student should understand that grades are based upon achievement of learning objectives and successful completion of assignments. If work is missing, for whatever reason, it becomes impossible for the instructor to evaluate it and assign a grade. It is highly recommended that students keep backup copies of all work submitted toward the unlikely event that it might need to be resubmitted. STUDENT WITHDRAWAL: If you cannot attend and complete this course, you should officially withdraw by calling Central Registration, 457-5231. Failure to officially withdraw will result in either an instructor withdraw (IW) or failing (F) grade. The last date to withdraw is identified on the second page of this syllabus handout. ACADEMIC HONESTY STATEMENT: Students are reminded that materials they may use as sources for this course may be subject to copyright protection. Additional information about copyright is provided on the library webpage at http://www.mccneb.edu/library, by your instructor, or by the College's Copyright Officer. In response to incidents of student dishonesty (cheating, plagiarism, etc.), the College imposes specific actions that may include receiving a failing grade on a test, failure in the course, suspension from the College, or dismissal from the College. The disciplinary procedures are available in the Counseling/Advising Centers and at http://www.mccneb.edu/procedures/V-4_Student_Conduct_and_Discipline.htm. Please note: ANY sharing or transfer of assigned work or test contents or answers between a student and any other person or party; in part or in whole; whether by disk exchange, E-mail, manual transcription, co-development of an assignment, or any other means; unless authorized by the instructor in advance in accordance with the guidelines in the following paragraph; will be considered academic misconduct and be sanctioned with disciplinary action in accordance with the above paragraph. Both originating and receiving parties will be liable to such sanction. Sharing of class notes and handouts is authorized. Obtaining assistance from others (including tutors or lab techs) for specific programming issues or debugging is authorized. However, no further collaboration is authorized for any standard assignment. Students wishing to collaborate further must contact the instructor for special assignments. Such special assignments must clearly identify in advance which portions are the responsibility of each individual student wishing to collaborate. The learning objectives, level of difficulty, and typical work involved for each portion must be comparable to that for a single student working alone on the corresponding standard assignment. Each portion will be graded individually. Each portion must clearly represent the competency of the individual responsible for it, and only that individual. The instructor reserves the right to refuse any request for special assignments. Indications of unauthorized collaboration and/or intent to defraud include, but are not restricted to, assignments, submitted by students (not necessarily from the same section) individually under each of Metro Community College Page 4 of 8 Revised: May-03 their respective names; but which are essentially identical; are essentially identical except for mechanical changes such as differing variable or module names; are essentially identical except for differing comments; or exhibit essentially identical idiosyncratic features such as errors in syntax, style, logic, output formatting, or spelling. The same criteria apply to submissions, by one or more students, where those submissions bear indications of copying from any other unauthorized source. Authorized sources are the student textbook for the class, lecture notes, class handouts, and compiler/interpreter documentation and help materials. In summary, if you want a grade attached to your name and only your name (the only way I know MCC records grades), the work you submit must be your work and only your work. USE OF STUDENT WORK The ownership of student works submitted in fulfillment of classroom requirements shall remain with the student(s): By enrolling in classes offered by Metropolitan Community College, the student gives the College license to mark on, modify, and retain the work as may be required by the process of instruction, as described in the course syllabus. The institution shall not have the right to use the work in any other manner without the written consent of the student(s). Please note: Nothing in the preceding paragraph overrides the restrictions on sharing or distribution of solutions to assignments and tests or any other policy or procedure discussed above under the Academic Honesty Statement. ASSESSMENT OF STUDENT LEARNING PROGRAM Metropolitan Community College is committed to continuous improvement of teaching and learning. You may be asked to help us to accomplish this objective. For example, you may be asked to respond to surveys or questionnaires. In other cases, tests or assignments you are required to do for this course may be shared with faculty and used for assessment purposes. This will be done in accordance with FERPA guidelines. TECHNOLOGY RESOURCES: By using the information technology systems at MCC(including the computer systems and phones) you acknowledge and consent to the conditions of use as set forth in the Metropolitan Community College Procedures Memorandum on Acceptable Use of Information Technology and Resources. It is your responsibility as a student to be familiar with these procedures. The full text of the Procedures Memorandum may be found at the following website: http://www.mccneb.edu/itprocedures.htm USE OF COLLEGE COMPUTERS When you use computers in College computer labs, learning centers, libraries and many classrooms, you will need to login using your student username and password. Your username is the same as your WebAdvisor username and your initial password is your student ID with leading zeros to make it seven Metro Community College Page 5 of 8 Revised: May-03 digits. If you need assistance, please contact staff at any of the computer labs, learning centers and libraries; your instructor may also be able to help. It is recommended that students save their files to removable media often as they work. The College reserves the right to take steps necessary to maintain the confidentiality of student identity information through the use of automatic logouts and screensavers. EDUCATIONAL SERVICES PROGRAM AREA IDENTIFICATION: Program Area: Dean: Academic Dean’s office phone: Computer Technology and Visual Arts Tom Pensabene 457-2660 SECTION IV: INSTRUCTOR RESPONSIBILITIES METHODS OF INSTRUCTION: In each lecture during this course, the instructor will cover material the student needs to learn and accomplish. In addition, written handouts will be provided from time to time. These will be used to supplement the text material and expand the course. Instruction will consist mainly of lecture material presented by the instructor. In some classes, group discussion and demonstration will be utilized. In all meetings, discussion opportunities will be provided and the student is encouraged to ask questions and clarify information as the instructor is lecturing and/or presenting material. METHODS OF ASSESSING STUDENT PROGRESS: Student progress is assessed through the completion of assigned projects and tests. A summary of programming assignments and tests may be found at the end of the syllabus under the heading PROJECTED SCHEDULE OF ASSIGNMENTS. Attendance and class participation may also be taken into consideration. The majority of programming assignments require the student to take a basic set of program requirements and, based on knowledge gained from reading and class, develop a program using the typical program development process. Work will be evaluated on the adequacy of program planning; correctness of coding generated; usage of comments to describe and clarify program logic, data element usage, and input/output requirements; adequacy of program testing procedures; and adequacy of program documentation. Of course, the program should also run correctly. Typical point assignments for these various aspects of programming for a 25 point program is as follows: 1 input layout(s) Usage of comments in program: 2 standard coding style & related 1 printer/output layout(s) 1 general description of the program issues 1 hierarchy diagram 1 misc. input/output requirements 2 correct procedural logic/method 2 flowchart or pseudocode 1 purpose & use of each variable 2 correct compile (variable table) 10 correct run 1 program logic (for each --------function/module) 25 total Full points are awarded for the inclusion of the specified item(s), with points being deducted for notable problems. Exams consist multiple choice, true/false, fill-in-the-blank questions and short programming segments. Metro Community College Page 6 of 8 Revised: May-03 CRITERIA FOR DETERMINING FINAL COURSE GRADE: A percentage grade will be obtained by dividing the total points a student earns by the total possible points for the course. The points for each assignment and test may be found in the PROJECTED SCHEDULE OF ASSIGNMENTS found at the end of the syllabus. The percentage grade will then determine the letter grade for the course, according to the following table: Letter Grade Percentage Range Point Range A 90% 100% 540 600 B 80% 89.9% 480 539 C 70% 79.9% 420 479 D 60% 69.9% 360 419 F 0% 59.9% 0 359 MAKE-UP TEST PROCEDURES: Students MUST be present on the day of an announced test. If the instructor is informed BEFORE THE TEST concerning a valid absence, other arrangements MAY be made. There will be no retakes of tests. Test dates are not firm and are therefore subject to change. LATE ASSIGNMENTS: Assignments turned in late may lose 10% per class day for up to a week and may then receive a grade of 0. Assignments may not be accepted after the test has been given. Also, see “Attendance” above. MAINTENANCE OF STUDENT RECORDS: Test will be returned after grading for review in class and then recollected and retained for record keeping purposes. All other work is graded and returned as soon as possible, usually by the following week. All grades are kept by the instructor in a grade book and on computer, which students may see at any time by asking the instructor. SECTION V: SCHEDULE OF ASSIGNMENTS: Wk Date Topics 1 3/10/05 CPT 123 Review Introductions Control Structures Functions Storage classes & Scope Recursion C++ string Class Arrays Chs. 1B6 Chs. 1-2 Chs. 3-4 5.1-8 5.11-12 5.13-15 n/a 6.1-5, 6.9 Ch. 1-9 Chs. 1-2 Chs. 4-5 Chs. 6-7 Ch. 7, pp. 334-40 Ch. 16 (new) Ch. 8, pp. 399-415 Ch. 9 #1 (4.22, 5.42) 50 2 3/17 Random number generation Sorting Arrays 5.9-10 6.6-7 #2 (6.35, 7.24) 50 Searching Arrays 6.8 Pointers Simulated Call-(Pass-)by-Reference Volatile Type Qualifier Suffixes for int & float Constants Ch. 7 7.4 14.7 14.8 App. G (new?) Ch.19, pp. 1151-67, 1172-83 Ch. 13, pp. 734-6, Ch. 19, pp. 1134-51 Ch. 13 (125 review) Ch. 13, pp. 709-10 Metro Community College Deitel Page 7 of 8 Projects Malik Revised: May-03 Points Assignment #1 due 3 3/24 Characters & Strings Formatted Input/Output Files Assignment #2 due Ch. 8 Ch. 9 11.1-5 Ch. 9 (123 review) Compare Ch. 3 Compare Ch. 3 #3 (11.7-10) 50 4 3/31 Structures Unions Bitwise Operations Enumerations Namespaces More About Files Review for midterm test Assignment #3 due 10.1-7 10.8 10.9-10 10.11 n/a 11.6-10, 14.9 Ch. 10 (125 review) #4 (10.10, 10.13-14) 50 Ch. 8 (123 review) Ch. 8 (123 review) Compare App. E 5 4/7 MIDTERM TEST All above material 6 4/14 Self-Referential Structures Dynamic Memory Allocation Linked Lists Searching Linked Lists Sorting Linked Lists Assignment #4 due 12.1-2 12.3, 14.11 12.4 Stacks Queues Circular Queues Trees 12.5 12.6 7 4/21 150 Ch. 13, pp. 700-09 Compare Ch. 17 Ch. 19, pp. 116772, 1184-93 12.7 8 4/28 The C++ Standard Template Library Graphs (in the topological sense) 9 5/5 Preprocessor Creating a Project Make Files Variable-Length Argument Lists Assignment #5 due Ch. 13 14.5 14.2, 4, 6, 10, 12 Ch. 18, pp. 1018-80 Ch. 18, pp. 10801123 Ch. 20 #5 (12.12) 50 #6 (13.7, 14.2) 50 Ch. 22 Ch. 21 14.3 10 5/12 Advanced Topics Course Review Assignment #6 due 11 5/19 Final Exam 150 600 The schedule of assignments is subject to change by the instructor. In the event the College closes classes for any reason, the dates of the scheduled activities will be followed as outlined above. Metro Community College Page 8 of 8 Revised: May-03