School of Engineering and Applied Science
Department of Electrical Engineering and Computer Science
CSci 131, Section 10 -- Data Structures
Spring 1998 Course Syllabus
Prof. Michael B. Feldman

Attendance

Attendance is required in both lecture and lab, and important work will be done in both. If you have an unavoidable need to be absent, you do not need special permission, but you are responsible for the work covered even if you are not in class.

Office hours

Lecturer, Rm 642 Academic Center: T 2-5 PM, W 2-6 PM, Th 2-5 PM, and also after class. Lab Assistant, Rm 636 Academic Center: 10-AM - 12 Noon, Wednesday. You do not need an appointment to come to office hours; just show up and take your turn. Office hours, both the lecturer's and the lab instructor's, are an important way for you to get help or to discuss anything you have on your mind. We are there to help you; that is an important part of our job. Please make good use of these hours; you are cheating yourself if you do not.

Electronic mail (e-mail)

Prof. Feldman, mfeldman@seas.gwu.edu; Jinsong Dai (TA), dai@seas.gwu.edu.

Part of your first-week assignment is to learn to write and send e-mail. Both the lecturer and the lab instructor read e-mail at least once a day; you are sure to get a quick response if you make good use of this system. If you have never used e-mail before, you are in for a treat--it is fun!

Required Textbook

The required text is Feldman, Software Construction and Data Structures with Ada 95, Addison-Wesley, published June 1996 (ISBN 0-201-88795-9). Read each chapter during the week it is assigned. The book discusses much more than I can cover in class, and I will cover things not in the book. You must come to class prepared!

Course Schedule

Week 1

1/13

Chapter 1

Ada Review; Abstract Data Types

Week 2

1/20

Chapter 2

ADTs continued

Week 3

1/27

Chapter 3

Recursion; "big O"

Week 4

2/3

Chapter 4

Advanced array types

Week 5

2/10

Chapter 5

Generic units

Week 6

2/17

Chapter 6

Variant and tagged records

Week 7

2/24

Chapter 7

Using Stacks and Queues

Week 8

3/3

MIDTERM EXAM

Covers Chaps. 1-7

Week 9

3/10

Chapter 8

Linked lists

3/17

SPRING RECESS - NO CLASS

Week 10

3/24

Chapter 9

Linked lists, continued

Week 11

3/31

Chapter 10

Directed graphs

Week 12

4/7

Chapter 11

Binary trees

Week 13

4/14

Chapter 13

Hash tables

Week 14

4/21

Chapter 14

Internal sorts

Week 15

4/28

Review

About Ada 95

We, like about 150 other colleges and universities, are using Ada 95 in this course because we are convinced it is absolutely the best choice for a course of this type. We have used Ada here since 1985, and Ada 95 since 1995, and it works!

The basic syntax of Ada is very similar to Pascal, and not very difficult; if you have had a course in Pascal, C, C++, or Java, you will probably find it straightforward to learn Ada. Hundreds of students like you have taken CSci 131 successfully. If you have not previously studied any of these programming languages, you are much better off to take CSci 51 before attempting this course.

If you have not previously studied the basics of Ada, you will find it helpful to read the first 9 chapters of the text used in CSci 51, which is Feldman/Koffman, Ada 95 Problem-Solving and Program Design, Addison Wesley, published Feb. 1996 (ISBN 0-201-30485-6). Alternatively, if you are experienced with C or C++, you might find Johnston, Ada 95 for C and C++ Programmers, Addison Wesley 1997 (ISBN 0-201-40363-3), to be useful in picking up Ada.

More information about Ada 95 (compiler availability, etc.) will be given in class. You can also learn lots about this interesting language on the web at http://www.acm.org/sigada/education.

Examinations

There will be a one-hour midterm and a two-hour final exam, both strictly timed. These will be open-book, open-notes exams. If you are coming to class regularly, and keeping up with the reading and the projects, the exams should not be difficult for you. Exams will require a mixture of reading and interpreting short program segments, writing short program segments, and short "essay" questions.

Quizzes

There may be one or more unnanounced quizzes during the lecture period. The best way to avoid unannounced quizzes is to come to class regularly, participate actively, and keep up with the reading.

Projects

There will be five or six projects. Details will be given to you separately, but, in summary, the programming part of these will be written in Ada 95. In principle you will use the GW computing facilities. You may also use a computer at home or at work, but must log in to the GW system frequently (once a week) to check for e-mail and download files.

Projects must represent the results of your own work. I cannot prevent your speaking with friends to sketch out a solution. But if you collaborate on the detailed design or coding, or copy a program from an acquaintance, then submit the results as your own work, I will charge you with plagiarism, and I will win. Please read the handout on Plagiarism and Collaboration.

Lab Exercises

Written lab exercises may not be graded, but they will be checked, and you must turn them in.

Grading

Your grade in the course is based on these weighting factors: homework 5%, midterm exam 25%; final exam 35%; programming projects 35%. Conversion from numerical to letter grades is done only when final grades are to be assigned. Grades are usually adjusted to the overall performance of the class, although there is no formal "curve" used. Quizzes, if any, will count a few percent of the grade.

Withdrawals and Incompletes

Under University and SEAS regulations, here are the rules for withdrawing from courses:

  • During the first four weeks: you can withdraw using a simple Drop/Add (Registration Transaction) form. The course disappears from your transcript.
  • After four weeks but before Preregistration begins: you can withdraw using a simple Drop/Add but the grade W appears on your transcript. This has no effect on your grade-point average.
  • After Preregistration begins but before the end of classes: this is considered a "late withdrawal." You must complete a SEAS Late Withdrawal form, which requires the signatures of the instructor, your advisor, the EECS Department Chair, and the SEAS Associate Dean. I will always sign a late withdrawal form, as long as classes have not ended for the semester. I will not sign a withdrawal form after the last class!

Under University regulations, and my own policies, here are the rules for Incomplete grades:

  • A grade of I (Incomplete) may be assigned only when the student has really special circumstances such that (s)he cannot finish the work of the course. I follow the University regulations, and do not give Incompletes unless the situation is truly unusual. Do not ask for an Incomplete just to gain more time to finish projects or raise a low grade. I will almost always say no.

An Incomplete grade is undesirable. You are required to remove the I by completing the work of the course. Taking the course a second time does not (NOT!) remove the original I. Under SEAS rules, an Incomplete not removed within one year becomes an F.