Syllabus of Data Structure And Algorithm

Course Title: Data Structures and Algorithms
Course no: CSC-154 Full Marks: 70+10+20
Credit hours: 3 Pass Marks: 28+4+8

Nature of course: Theory (3 Hrs.) + Lab (3 Hrs.)

Course Synopsis: Study of basic data structure vocabulary, the concept of an
algorithm.

Goal: To provide the concept of data structure and its implementation using
programming techniques.
Course Contents:

Unit 1: 14 Hrs.
1.1 Introduction to Data Structures: Information and its meaning, Array in C++:
The array as an ADT, Using one dimensional array, Two dimensional array,
Multi dimensional array, Structure , Union, Classes in C++.
1.2 The Stack: Introduction, definition, primitive operation, the stack as an abstract  data type, implementing the POP operation, testing for exceptional condition,  implementing the PUSH operation.
1.3 The Infix, Postfix & Prefix: Introduction, evaluating the postfix operation,
program to evaluate the postfix operation, limitation of program, converting
from one to another.
1.4 Recursion: Introduction, factorial functions, multiplication of natural numbers,  Fibonacci sequence, binary search, the tower of Hanoi problem, translation from  prefix to postfix using recursion.

Unit 2: 31 Hrs.
2.1 Queues: Introduction, the queue and its sequential representation: The queue as  an abstract data type, implementation of queue, inserts operation, priority queue.
2.2 Linked Lists: Introduction, inserting and deleting the nodes from a list, linked
implementation of stack, get-node and free-node operation, linked  implementation of queue. Linked list as a data structure, circular lists, stack as a
circular list, queue as a circular list.
2.3 Tree: Introduction, Binary Trees: operation on Binary Trees, application of
Binary Trees. Binary Tree Representation: node representation of binary tree,
internal and external nodes, implicit array representation of binary tree, binary
tree traversal, threaded binary tree, heterogeneous binary tree. The Huffman
algorithm. Representing lists as binary trees. Trees and their application.
2.4 Sorting: Introduction, O notation, efficiency of sorting, exchange sort: bubble
sort, quick sort.
2.5 Selection and Tree Sorting: Introduction, straight selection sort, binary tree sort,  heap-sort, insertion sort, merge and radix sort.
2.6 Searching: Introduction, sequential searching, binary search, interpolation
search, tree search, general search tree, hashing.
2.7 Graphs: Introduction, linked representation of graphs.
2.8 Algorithm: Introduction, design of algorithm, algorithm validation, analysis of  algorithm, algorithm testing. sub-algorithm

Laboratory works:
1. Write a code to multiply two matrices and get the transpose of the third one.
2. Write a code to implement the stack, that should check overflow and
underflow also.
3. Write a code to convert any prefix number to postfix.
4. Write a code to convert any infix number to postfix.
5. Write a code to convert any post fix number to prefix.
6. Implement tower of Hanoi.
7. Write a code to implement different sorting techniques.
8. Write a code to demonstrate the binary search.
9. Write a code to implement the queue.
10. Write a code to convert stack operation to queue operation.

Text books: Data Structure Using C & C++, Langsam Yedidyah, Augenstein Moshe J.,  Tennenbaum Aaron M., PHI

Reference: The Design and Analysis of Algorithm, Nitin Upadhyay, SK Kataria &
Sons.

Homework  Assignment: Assignment should be given from the above units in throughout the  semester.

Computer usage: No specific
Prerequisite: C

Category content:
         Science Aspect: 40%
         Design Aspect: 60%

Comments