Data Structures

Welcome to Data Structures (EE432) Course.

Class Timings:

This course is being taught by another staff member. Please check with the department registration.

Textbooks:

N. Dale C++ Plus Data Structures , Jones and Bartlett Publishers, 3rd edition, 2003.

Visual Studio:

Download from here .

Registration:

Please click here to register for the first time. (Please write your full name in Arabic ).

Handouts:

Lecture: 1 2 3 4 5 6 7 8 9 10 11 12 .

Marks:

Click here .

Assignments:

Click here .

Prerequisites

C++ in GS200.

  • Description and Objectives:

    The purpose of this course is to introduce you to the exciting world of data structures, an issue central to the art of computer programming. At the end of the course you will be equipped with the tools of data organization to enable you to write simple, clear, and efficient programs. The course will be structured around a comprehensive set of computer assignments to enable you to get hands on experience. Our programming language of choice will be C++.

  • - C++ Review

    - Comparison of Algorithms

    - Stacks and Templates

    - Queues

    - Unsorted and Sorted Lists

    - Linked Structures

    - Lists Plus

    - Recursion

    - Inheritance

    - Binary Search Tree

    - Heaps and Priority Queues

    - Graphs

    - Sorting and Searching (if time permits)

  • Grading will be based on three exams, 6-7 quizzes and 4-5 programming assignments. Specifically, quizzes will be announced at least one class period in advance. There will be two mideterm exams and a final. The material covered in the exams will be drawn from the lectures and the quizzes. There will be several programming assignments which will be done in groups. The goal of the assignments is to provide you with hands-on experience with handling various kinds of data structures. In the lectures, you will be introduced to data structures at an abstract level and in the assignments you will write code to implement and use these data structures. Specific details and due dates will be announced in class.

  • Slides, assignments, and other useful information will be posted on the course web page. Regular attendance is highly recommended. If you miss a class, you are responsible for all material covered or assigned in class. The programming assignments are to be completed in groups, however, all members of a team are expected to fully understand the structure of the code and the implemented algorithms. Discussion of the programming assignments is allowed and encouraged. However, each team is expected to do its own work. Assignments which are too similar will receive a zero. No late programming assignments will be accepted unless there is an extreme emergency.