This course aims to enable students to:
Basic Terminologies, Elementary Data Organizations, Data Structure Operations (insertion, deletion, traversal etc.), Analysis of an Algorithm, Asymptotic Notations, Time-Space trade off. Searching: Linear Search and Binary Search Techniques and their complexity analysis.
ADT Stack and its operations: Algorithms and their complexity analysis, Applications of Stacks: Expression Conversion and evaluation. ADT queue, Types of Queue: Simple Queue, Circular Queue, Priority Queue; Operations on each type of Queue: Algorithms and their analysis.
Singly linked lists: Representation in memory, Algorithms of operations: Traversing, Searching, Insertion, Deletion; Linked representation of Stack and Queue, Header nodes, Doubly linked list, Circular Linked Lists. Trees: Basic Tree Terminologies, Different types of Trees: Binary Tree, Threaded Binary Tree, Binary Search Tree, AVL Tree; Tree operations and their algorithms with complexity analysis. Applications of Binary Trees. B Tree, B+ Tree: definitions, algorithms and analysis.
Sorting algorithms: Selection Sort, Bubble Sort, Insertion Sort, Quick Sort, Merge Sort, Heap Sort; Performance and Comparison among all methods, Hashing.
Basic Terminologies and Representations, Graph search and traversal algorithms and complexity analysis.
The student will be able to: