Data+Structures+and+Algorithms
Data+Structures+and+Algorithms
Data+Structures+and+Algorithms
Data structure refers to the process whereby the data can be stored and organized in a way that the user can access and utilize the data efficiently.
Various algorithms are present to work with the data structures. Therefore, the data structure includes a group of data values, their relation to other
elements, and also the operations that can be carried over the data values.
Programs=algorithms+data structures
Data structures=related data+allowed operations on that data
4. What is a stack data structure? What are the applications 2. Object Oriented Programming
of stack? • Class and Objects
5. What are different operations available in stack data • Methods
structure?
3. Stacks
6. What is a queue data structure? What are the applications
• Stacks Operations
of queue?
• Methods
7. What are different operations available in queue data
4. Queue
structure?
• Queue Operations
8. Differentiate between stack and queue data structure.
• Python Implementation
Types of Data Structures
Data structures are broadly classified into primitive and non-primitive types. Primitive data types are the building blocks of non-primitive data structures.
Examples of primitive data types are integer, float, and string. Collection of primitive data structures form non-primitive data structures like lists, tuples, sets
etc.
Non-primitive data structures are again broadly classified into two types based on how they store the data:
Linear data structures like stacks, queues, deques and linked lists are user-defined data structures. The term user-defined means that the user is allowed to
define those data structures on their own which we will be learning in the subsequent sessions. In this course, we will be focusing only on linear data
structures.
Data Structures
Integer Real Character Boolean Linear Data Structures Non-linear Data Structures
Arrays Trees
Linked List Graphs
Stacks
Queues
RAM Vs Storage:
• RAM is a temporary memory space whereas storage is permanent memory space.
• All data storage and processing during computation occupies memory, that is RAM as it is designed to provide fast run-time access to the data.
Hence, it is crucial to choose the right data structure for efficient computation.
• RAM is available in GBs as opposed to storage that is available in TBs.
Object Oriented Programming:
Object-Oriented Programming is a methodology or paradigm to design a program using classes and objects. It simplifies software development and
maintenance by providing some concepts: Object. Class. Inheritance.
1. Class:
A class is a collection of objects. A class contains the blueprints or the prototype from which the objects are being created. It is a logical entity that contains
some attributes and methods.
• Classes are created by keyword class.
• Attributes are the variables that belong to a class.
• Attributes are always public and can be accessed using the dot (.) operator. Eg.: Myclass.Myattribute
2. Objects:
The object is an entity that has a state and behavior associated with it.
An object consists of :
• State: It is represented by the attributes of an object. It also reflects the properties of an object.
• Behavior: It is represented by the methods of an object. It also reflects the response of an object to other objects.
• Identity: It gives a unique name to an object and enables one object to interact with other objects.
class Dog: class Dog:
Method vs Functions:
1. Python functions are called generically, methods are called on an object since we call a method on an object, it can access the data within it.
2. A 'Method' may alter an object’s state, but Python 'Function' usually only operates on it, and then returns a valu
● Inheritance: Inheritance is the capability of one class to derive or inherit the properties from another class. The class that derives properties is called
the derived class or child class and the class from which the properties are being derived is called the base class or parent class.
● Polymorphism: Polymorphism simply means having many forms. For example, we need to determine if the given species of birds fly or not, using
polymorphism we can do this using a single function.
● Encapsulation: It describes the idea of wrapping data and the methods that work on data within one unit. This puts restrictions on accessing variables
and methods directly and can prevent the accidental modification of data.
● Data Abstraction: It hides the unnecessary code details from the user. Also, when we do not want to give out sensitive parts of our code
implementation and this is where data abstraction came.
Stacks: Stacks are data structures that follow Last In First Out order The element that enters the stack, at last, will be removed first. A stack of books is
an example of how a stack works. Then you saw how browser history or an undo button makes use of the stack data structure.
Stacks Operations:
string = "((O)"
print (string, "-", check (string))
Queues: Queues are data structures that follow First In First Out order The element that enters the queue first, will be removed first from the queue.
A ticket counter or a playlist of songs is an example of how a queue works. Then you saw how a shared office printer makes use of a queue data structure.
Queue Operations:
from pythonds. basic import Queue
● Enqueue(object element): It inserts an element to the rear of the queue.
● Dequeue(): It removes an element from the front of a queue. def hotPotato (namelist, num):
simqueue Queue() =
● isEmpty(): It returns true if a queue is empty; otherwise false. for name in namelist:
simqueue.enqueue (name)
● size(): It returns the size of the queue.
● peek(): It returns the element at the front of a queue but will while simqueue.size() > 1:
not remove it from queue. for i in range (num):
simqueue.enqueue (simqueue.dequeue())
Note:
In the user-defined class of 'Queue', you used the convention of the left simqueue.dequeue()
end as rear and the right end as the front. You learned that swapping the
front and rear ends of the queue will not change the FIFO property of the return simqueue.dequeue()
queue as long as insertion happens from the rear end and the removal
happens at the front end of any convention used.