KEMBAR78
Data Structures and Algorithms Week 1 | PDF | Queue (Abstract Data Type) | Algorithms
0% found this document useful (0 votes)
17 views12 pages

Data Structures and Algorithms Week 1

The document outlines the classifications of data structures into primitive and non-primitive types, detailing linear and non-linear structures. It also discusses common operations performed on data structures, such as insertion, deletion, and traversal, as well as the concept of abstract data types (ADTs). Additionally, it highlights the importance of algorithms in problem-solving and their analysis in terms of computational complexity.

Uploaded by

wild.butcute19
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
17 views12 pages

Data Structures and Algorithms Week 1

The document outlines the classifications of data structures into primitive and non-primitive types, detailing linear and non-linear structures. It also discusses common operations performed on data structures, such as insertion, deletion, and traversal, as well as the concept of abstract data types (ADTs). Additionally, it highlights the importance of algorithms in problem-solving and their analysis in terms of computational complexity.

Uploaded by

wild.butcute19
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PPTX, PDF, TXT or read online on Scribd
You are on page 1/ 12

CONCEPTS,

CLASSIFICATIONS
AND
OPERATIONS OF
DATA
STRUCTURE
CLASSIFICATIONS OF DATA
STRUCTURE
Data structures are classified based on how data
is organized, manipulated, and accessed.

The classifications can be broadly divided as


follows:
1. Primitive Data Structures
Examples:
Integer
Float
Character
Boolean
2. Non-Primitive Data Structures
More complex and derived from primitive types.
Sub-classifications:
a. Linear Data Structures
Elements are arranged sequentially, and traversal is
done one at a time.
Examples:
Linked List: Dynamic size, elements linked via
pointers.
Stack: Follows Last In First Out (LIFO) order.
Queue: Follows First In First Out (FIFO) order.
Deque: Double-ended queue allowing
insertions/removals from both ends.
Priority Queue: Elements prioritized based on a
b. Non-Linear Data Structures
Elements are not in a sequential manner and allow
hierarchical or interconnected relationships.
Examples:
Tree: Hierarchical structure with a root and
subtrees.
Graph: Set of vertices (nodes) connected by
edges, e.g., Directed Graph, Undirected Graph.
OPERATIONS ON DATA
STRUCTURE
The most common operations that can be performed
on data structures include:

Insertion: Adding an element to the structure.


Deletion: Removing an element from the structure.
Traversal: Accessing each element in the structure
(e.g., visiting each node of a tree).
Searching: Finding an element in the structure.
Updating: Modifying the data in the structure.
ABSTRACT DATA
TYPE
An abstract data type (ADT) is a logical description of
how data is viewed as well as the operations that are
allowed without regard to how they will be implemented.

Examples of Abstract Data Types:


Linked list – used for storing elements where each is a
separate object.
Stack – an ordered list in which the last element added
is the first element retrieved or removed (Last-In, First-
Out).
Queue – an ordered list in which the first element added
ABSTRACT DATA
TYPE

Tree – represents a hierarchical nature of a structure


in a graphical form.
Priority queue – a special type of queue where
elements are processed based on their order (natural
or custom).
Heap – a complete binary tree where the value of
each of each parent node is either higher or lower
than the value of its child nodes.
ALGORITHMS AND ITS
COMPLEXITY
An algorithm is a well-defined sequential computational
technique that accepts a value or a collection of values as
input and produces the output(s) needed to solve a problem.

Or we can say that an algorithm is said to be accurate if and


only if it stops with the proper output for each input instance.

NEED OF THE ALGORITHMS:


Algorithms are used to solve problems or automate tasks in a
systematic and efficient manner. They are a set of instructions
or rules that guide the computer or software in performing a
particular task or solving a problem.
ALGORITHMS AND ITS
COMPLEXITY
There are several reasons why we use algorithms:

Algorithms can perform tasks quickly and accurately, making them


an essential tool for tasks that require a lot of calculations or data
processing.
Algorithms are repeatable and produce consistent results every
time they are executed. This is important when dealing with large
amounts of data or complex processes.
Algorithms can automate repetitive tasks, reducing the need for
human intervention and freeing up time for other tasks.
Algorithms can be standardized and shared among different teams
or organizations, making it easier for people to collaborate and
ALGORITHM
ANALYSIS

Algorithm analysis is an important part of


computational complexity theory, which
provides theoretical estimation for the
required resources of an algorithm to solve a
specific computational problem.
ARRAY DATA
STRUCTURE
Array is a collection of items of the same variable type that
are stored at contiguous memory locations. It is one of the
most popular and simple data structures used in
programming.

Basic terminologies of Array


Array Index: In an array, elements are identified by their
indexes. Array index starts from 0.
Array element: Elements are items stored in an array and
can be accessed by their index.
Array Length: The length of an array is determined by the
number of elements it can contain.
ARRAY OPERATIONS
Common operations on an array include:

Access: To access an element, we use its index. Array


indexing is zero-based in most languages, so the first element
is at index 0. Example: arr[3] accesses the fourth element in
the array arr.
Insertion: Inserting an element into an array typically
involves shifting existing elements (for arrays with a fixed
size). Example: Inserting a new element at the end of an
array requires checking if there’s space and adding the
element.
Deletion: Removing an element involves shifting the

You might also like